
<!DOCTYPE HTML>
<html lang="" >
    <head>
        <meta charset="UTF-8">
        <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
        <title>logback中文网|第六章：Layouts</title>
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="description" content="logback中文网包含了logback中文文档，最新资讯，应用案例等。logback 继承自 log4j，它建立在有十年工业经验的日志系统之上。它比其它所有的日志系统更快并且更小，包含了许多独特并且有用的特性。"><meta name="keywords" content="logback中文文档, logback api文档, logback log4j,springboot logback,logback日志类型">
        <meta name="generator" content="GitBook 3.2.3">
        
        
        
    
    <link rel="stylesheet" href="gitbook/style.css">

    
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-highlight/website.css">
                
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-search/search.css">
                
            
                
                <link rel="stylesheet" href="gitbook/gitbook-plugin-fontsettings/website.css">
                
            
        

    

    
        
    
        
    
        
    
        
    
        
    
        
    

        
    
    
    <meta name="HandheldFriendly" content="true"/>
    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <link rel="apple-touch-icon-precomposed" sizes="152x152" href="gitbook/images/apple-touch-icon-precomposed-152.png">
    <link rel="shortcut icon" href="gitbook/images/favicon.ico" type="image/x-icon">

    
    <link rel="next" href="07第七章Filters.html" />
    
    
    <link rel="prev" href="05第五章Encoder.html" />
    

    </head>
    <body>
        
<div class="book">
    <div class="book-summary">
        
            
<div id="book-search-input" role="search">
    <input type="text" placeholder="Type to search" />
</div>

            
                <nav role="navigation">
                


<ul class="summary">
    
    

    

    
        
        
    
        <li class="chapter " data-level="1.1" data-path="./">
            
                <a href="./">
            
                    
                    Introduction
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2" data-path="01第一章logback介绍.html">
            
                <a href="01第一章logback介绍.html">
            
                    
                    第一章：logback 介绍
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3" data-path="02第二章架构.html">
            
                <a href="02第二章架构.html">
            
                    
                    第二章：架构
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4" data-path="03第三章logback的配置.html">
            
                <a href="03第三章logback的配置.html">
            
                    
                    第三章：logback 的配置
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.5" data-path="04第四章Appenders.html">
            
                <a href="04第四章Appenders.html">
            
                    
                    第四章：Appenders
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6" data-path="05第五章Encoder.html">
            
                <a href="05第五章Encoder.html">
            
                    
                    第五章：Encoder
            
                </a>
            

            
        </li>
    
        <li class="chapter active" data-level="1.7" data-path="06第六章Layouts.html">
            
                <a href="06第六章Layouts.html">
            
                    
                    第六章：Layouts
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.8" data-path="07第七章Filters.html">
            
                <a href="07第七章Filters.html">
            
                    
                    第七章：Filters
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.9" data-path="08第八章MDC.html">
            
                <a href="08第八章MDC.html">
            
                    
                    第八章：MDC
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.10" data-path="09第九章日志隔离.html">
            
                <a href="09第九章日志隔离.html">
            
                    
                    第九章：日志隔离
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.11" data-path="10第十章JMX配置器.html">
            
                <a href="10第十章JMX配置器.html">
            
                    
                    第十章：JMX 配置器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.12" data-path="11第十一章Joran.html">
            
                <a href="11第十一章Joran.html">
            
                    
                    第十一章：Joran
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13" data-path="12第十二章Groovy配置.html">
            
                <a href="12第十二章Groovy配置.html">
            
                    
                    第十二章：Groovy 配置
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.14" data-path="13第十三章从log4j迁移.html">
            
                <a href="13第十三章从log4j迁移.html">
            
                    
                    第十三章：从 log4j 迁移
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.15" data-path="14第十四章Receivers.html">
            
                <a href="14第十四章Receivers.html">
            
                    
                    第十四章：Receivers
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.16" data-path="15第十五章使用SSL.html">
            
                <a href="15第十五章使用SSL.html">
            
                    
                    第十五章：使用 SSL
            
                </a>
            

            
        </li>
    

    

    <li class="divider"></li>

    <li>
        <a href="https://www.gitbook.com" target="blank" class="gitbook-link">
            Published with GitBook
        </a>
    </li>
</ul>


                </nav>
            
        
    </div>

    <div class="book-body">
        
            <div class="body-inner">
                
                    

<div class="book-header" role="navigation">
    

    <!-- Title -->
    <h1>
        <i class="fa fa-circle-o-notch fa-spin"></i>
        <a href="." >第六章：Layouts</a>
    </h1>
</div>




                    <div class="page-wrapper" tabindex="-1" role="main">
                        <div class="page-inner">
                            
<div id="book-search-results">
    <div class="search-noresults">
    
                                <section class="normal markdown-section">
                                
                                <h2 id="&#x4EC0;&#x4E48;&#x662F;-layout&#xFF1F;">&#x4EC0;&#x4E48;&#x662F; layout&#xFF1F;</h2>
<p>layout &#x662F; logback &#x7684;&#x7EC4;&#x4EF6;&#xFF0C;&#x8D1F;&#x8D23;&#x5C06;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x8F6C;&#x6362;&#x4E3A;&#x5B57;&#x7B26;&#x4E32;&#x3002;<a href="https://logback.qos.ch/xref/ch/qos/logback/core/Layout.html" target="_blank"><code>Layout</code></a> &#x63A5;&#x53E3;&#x4E2D;&#x7684; <code>format()</code> &#x65B9;&#x6CD5;&#x63A5;&#x53D7;&#x4E00;&#x4E2A;&#x8868;&#x793A;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x7684;&#x5BF9;&#x8C61; (&#x4EFB;&#x4F55;&#x7C7B;&#x578B;) &#x5E76;&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;&#x4E32;&#x3002;<code>Layout</code> &#x63A5;&#x53E3;&#x7684;&#x6982;&#x8981;&#x5982;&#x4E0B;&#xFF1A;</p>
<pre><code class="lang-java"><span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">interface</span> <span class="hljs-title">Layout</span>&lt;<span class="hljs-title">E</span>&gt; <span class="hljs-keyword">extends</span> <span class="hljs-title">ContextAware</span>, <span class="hljs-title">LifeCycle</span> </span>{

  <span class="hljs-function">String <span class="hljs-title">doLayout</span><span class="hljs-params">(E event)</span></span>;
  <span class="hljs-function">String <span class="hljs-title">getFileHeader</span><span class="hljs-params">()</span></span>;
  <span class="hljs-function">String <span class="hljs-title">getPresentationHeader</span><span class="hljs-params">()</span></span>;
  <span class="hljs-function">String <span class="hljs-title">getFileFooter</span><span class="hljs-params">()</span></span>;
  <span class="hljs-function">String <span class="hljs-title">getPresentationFooter</span><span class="hljs-params">()</span></span>;
  <span class="hljs-function">String <span class="hljs-title">getContentType</span><span class="hljs-params">()</span></span>;
}
</code></pre>
<p>&#x8FD9;&#x4E2A;&#x63A5;&#x53E3;&#x76F8;&#x5BF9;&#x7B80;&#x5355;&#xFF0C;&#x4F46;&#x662F;&#x5B83;&#x53EF;&#x4EE5;&#x6EE1;&#x8DB3;&#x5927;&#x90E8;&#x5206;&#x7684;&#x683C;&#x5F0F;&#x5316;&#x9700;&#x6C42;&#x3002;</p>
<h2 id="logback-classic">Logback-classic</h2>
<p>logback-classic &#x4EC5;&#x4EC5;&#x7528;&#x6765;&#x5904;&#x7406; <a href="https://logback.qos.ch/xref/ch/qos/logback/classic/spi/ILoggingEvent.html" target="_blank"><code>ch.qos.logback.classic.spi.ILoggingEvent</code></a> &#x7C7B;&#x578B;&#x7684;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x3002;&#x6211;&#x4EEC;&#x5C06;&#x5728;&#x8FD9;&#x4E2A;&#x90E8;&#x5206;&#x8BF4;&#x660E;&#x8FD9;&#x4E2A;&#x4E8B;&#x5B9E;&#x3002;</p>
<h2 id="&#x5B9A;&#x5236;-layout">&#x5B9A;&#x5236; Layout</h2>
<p>&#x8BA9;&#x6211;&#x4EEC;&#x4E3A; logback-classic  &#x6A21;&#x5757;&#x5B9E;&#x73B0;&#x4E00;&#x4E2A;&#x7B80;&#x5355;&#x4F46;&#x662F;&#x5B9E;&#x7528;&#x7684;&#x529F;&#x80FD;&#xFF0C;&#x6253;&#x5370;&#x5E94;&#x7528;&#x542F;&#x52A8;&#x6240;&#x8017;&#x8D39;&#x7684;&#x65F6;&#x95F4;&#xFF0C;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x7684;&#x7EA7;&#x522B;&#xFF0C;&#x88AB;&#x7EFC;&#x62EC;&#x53F7;&#x5305;&#x88F9;&#x7684;&#x8C03;&#x7528;&#x8005;&#x7EBF;&#x7A0B;&#xFF0C;logger &#x540D;&#xFF0C;&#x7834;&#x6298;&#x53F7;&#x540E;&#x9762;&#x8DDF;&#x65E5;&#x5FD7;&#x4FE1;&#x606F;&#xFF0C;&#x4EE5;&#x53CA;&#x65B0;&#x8D77;&#x4E00;&#x884C;&#x3002;</p>
<p>&#x7C7B;&#x4F3C;&#x4E0B;&#x9762;&#x7684;&#x8F93;&#x51FA;&#xFF1A;</p>
<pre><code class="lang-java"><span class="hljs-number">10489</span> DEBUG [main] com.marsupial.Pouch - Hello world.
</code></pre>
<p>&#x4E0B;&#x9762;&#x662F;&#x4E00;&#x79CD;&#x53EF;&#x80FD;&#x7684;&#x5B9E;&#x73B0;&#xFF1A;</p>
<blockquote>
<p>  Example: MySampleLayout.java</p>
</blockquote>
<pre><code class="lang-java"><span class="hljs-keyword">package</span> chapters.layouts;

<span class="hljs-keyword">import</span> ch.qos.logback.classic.spi.ILoggingEvent;
<span class="hljs-keyword">import</span> ch.qos.logback.core.LayoutBase;

<span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">MySampleLayout</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">LayoutBase</span>&lt;<span class="hljs-title">ILoggingEvent</span>&gt; </span>{

  <span class="hljs-function"><span class="hljs-keyword">public</span> String <span class="hljs-title">doLayout</span><span class="hljs-params">(ILoggingEvent event)</span> </span>{
    StringBuffer sbuf = <span class="hljs-keyword">new</span> StringBuffer(<span class="hljs-number">128</span>);
    sbuf.append(event.getTimeStamp() - event.getLoggingContextVO.getBirthTime());
    sbuf.append(<span class="hljs-string">&quot; &quot;</span>);
    sbuf.append(event.getLevel());
    sbuf.append(<span class="hljs-string">&quot; [&quot;</span>);
    sbuf.append(event.getThreadName());
    sbuf.append(<span class="hljs-string">&quot;] &quot;</span>);
    sbuf.append(event.getLoggerName();
    sbuf.append(<span class="hljs-string">&quot; - &quot;</span>);
    sbuf.append(event.getFormattedMessage());
    sbuf.append(CoreConstants.LINE_SEP);
    <span class="hljs-keyword">return</span> sbuf.toString();
  }
}
</code></pre>
<p><code>MySampleLayout</code> &#x7EE7;&#x627F;&#x81EA; <a href="https://logback.qos.ch/xref/ch/qos/logback/core/LayoutBase.html" target="_blank"><code>LayoutBase</code></a>&#x3002;&#x8FD9;&#x4E2A;&#x7C7B;&#x7BA1;&#x7406;&#x6240;&#x6709; layout &#x5B9E;&#x4F8B;&#x7684;&#x72B6;&#x6001;&#x4FE1;&#x606F;&#xFF0C;&#x4F8B;&#x5982;&#xFF1A;layout &#x662F;&#x5426;&#x542F;&#x52A8;&#x6216;&#x8005;&#x505C;&#x6B62;&#xFF0C;&#x5934;&#x90E8;&#xFF0C;&#x5C3E;&#x90E8;&#x4EE5;&#x53CA;&#x5185;&#x5BB9;&#x7C7B;&#x578B;&#x6570;&#x636E;&#x3002;&#x5B83;&#x8BA9;&#x5F00;&#x53D1;&#x8005;&#x901A;&#x8FC7;&#x81EA;&#x5DF1; <code>Layout</code> &#x96C6;&#x4E2D;&#x5728;&#x65E5;&#x5FD7;&#x5177;&#x4F53;&#x7684;&#x683C;&#x5F0F;&#x5316;&#x4E0A;&#x3002;<code>LayoutBase</code> &#x7C7B;&#x662F;&#x901A;&#x7528;&#x7684;&#x3002;&#x5728;&#x5B83;&#x7684;&#x7C7B;&#x58F0;&#x660E;&#x4E0A;&#xFF0C;<code>MySampleLayout</code> &#x7EE7;&#x627F; <code>LayoutBase&lt;ILoggingEvent&gt;</code>&#x3002;</p>
<p>&#x5728;&#x4E0A;&#x9762;&#x8FD9;&#x4E2A;&#x4F8B;&#x5B50;&#x4E2D;&#xFF0C;<code>doLayout</code> &#x65B9;&#x6CD5;&#x5FFD;&#x7565;&#x4E86;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x4E2D;&#x4EFB;&#x4F55;&#x53EF;&#x80FD;&#x7684;&#x5F02;&#x5E38;&#x3002;&#x5728;&#x5B9E;&#x9645;&#x5E94;&#x7528;&#x4E2D;&#xFF0C;&#x4F60;&#x53EF;&#x80FD;&#x9700;&#x8981;&#x6253;&#x5370;&#x5F02;&#x5E38;&#x4FE1;&#x606F;&#x3002;</p>
<h3 id="&#x914D;&#x7F6E;&#x81EA;&#x5B9A;&#x4E49;&#x7684;-layout">&#x914D;&#x7F6E;&#x81EA;&#x5B9A;&#x4E49;&#x7684; layout</h3>
<p>&#x914D;&#x7F6E;&#x81EA;&#x5B9A;&#x4E49;&#x7684; layout &#x8DDF;&#x5176;&#x5B83;&#x7684;&#x7EC4;&#x4EF6;&#x4E00;&#x6837;&#x7684;&#x914D;&#x7F6E;&#x3002;&#x6839;&#x636E;&#x4E4B;&#x524D;&#x63D0;&#x5230;&#x7684;&#xFF0C;<code>FileAppender</code> &#x53CA;&#x5176;&#x5B50;&#x7C7B;&#x671F;&#x671B;&#x4E00;&#x4E2A; encoder&#x3002;&#x4E3A;&#x4E86;&#x53BB;&#x6EE1;&#x8DB3;&#x8FD9;&#x4E2A;&#x9700;&#x6C42;&#xFF0C;&#x6211;&#x4EEC;&#x5C06;&#x4E00;&#x4E2A;&#x5305;&#x88F9;&#x4E86;&#x6211;&#x4EEC;&#x81EA;&#x5DF1;&#x5B9A;&#x4E49;&#x7684; <code>MySampleLayout</code> &#x7684; <code>LayoutWrappingEncoder</code> &#x7684;&#x5B9E;&#x4F8B;&#x4F20;&#x9012;&#x7ED9; <code>FileAppender</code>&#x3002;&#x4E0B;&#x9762;&#x662F;&#x914D;&#x7F6E;&#x793A;&#x4F8B;&#xFF1A;</p>
<blockquote>
<p>  Example: <em>sampleLayoutConfig.xml</em></p>
</blockquote>
<pre><code class="lang-xml"><span class="hljs-tag">&lt;<span class="hljs-name">configuration</span>&gt;</span>

  <span class="hljs-tag">&lt;<span class="hljs-name">appender</span> <span class="hljs-attr">name</span>=<span class="hljs-string">&quot;STDOUT&quot;</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.core.ConsoleAppender&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">encoder</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.core.encoder.LayoutWrappingEncoder&quot;</span>&gt;</span>
      <span class="hljs-tag">&lt;<span class="hljs-name">layout</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;chapters.layouts.MySampleLayout&quot;</span> /&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">encoder</span>&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">appender</span>&gt;</span>

  <span class="hljs-tag">&lt;<span class="hljs-name">root</span> <span class="hljs-attr">level</span>=<span class="hljs-string">&quot;DEBUG&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">appender-ref</span> <span class="hljs-attr">ref</span>=<span class="hljs-string">&quot;STDOUT&quot;</span> /&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">root</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">configuration</span>&gt;</span>
</code></pre>
<p><a href="https://logback.qos.ch/xref/chapters/layouts/SampleLogging.html" target="_blank"><code>chapters.layouts.SampleLogging</code></a> &#x8FD9;&#x4E2A;&#x7B80;&#x5355;&#x7684;&#x5E94;&#x7528;&#x901A;&#x8FC7;&#x7B2C;&#x4E00;&#x4E2A;&#x53C2;&#x6570;&#x63A5;&#x6536;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#xFF0C;&#x7136;&#x540E;&#x6253;&#x5370;&#x4E86;&#x4E00;&#x4E2A; debug &#x4FE1;&#x606F;&#xFF0C;&#x63A5;&#x7740;&#x6253;&#x5370;&#x4E86; error &#x4FE1;&#x606F;&#x3002;</p>
<p>&#x5728; <em>logback-examples</em> &#x6587;&#x4EF6;&#x5939;&#x4E0B;&#x901A;&#x8FC7;&#x4EE5;&#x4E0B;&#x547D;&#x4EE4;&#x6765;&#x8FD0;&#x884C;&#xFF1A;</p>
<pre><code class="lang-bash">java chapters.layouts.SampleLogging src/main/java/chapters/layouts/sampleLayoutConfig.xml
</code></pre>
<p>&#x5C06;&#x4F1A;&#x8F93;&#x51FA;&#xFF1A;</p>
<pre><code class="lang-java">0 DEBUG [main] chapters.layouts.SampleLogging - Everything&apos;s going well
0 ERROR [main] chapters.layouts.SampleLogging - maybe not quite...
</code></pre>
<p>&#x8FD9;&#x79CD;&#x8DB3;&#x591F;&#x7B80;&#x5355;&#x3002;&#x8BFB;&#x8005;&#x5E94;&#x8BE5;&#x4F1A;&#x53D1;&#x73B0;&#xFF0C;&#x5728; <a href="https://logback.qos.ch/xref/chapters/layouts/MySampleLayout2.html" target="_blank"><code>MySampleLayout2.java</code></a> &#x4E2D;&#xFF0C;&#x6211;&#x4EEC;&#x81EA;&#x5B9A;&#x4E49;&#x7684; layout &#x505A;&#x4E86;&#x4E00;&#x70B9;&#x70B9;&#x7684;&#x4FEE;&#x6539;&#x3002;&#x6B63;&#x5982;&#x672C;&#x624B;&#x518C;&#x4E00;&#x76F4;&#x63D0;&#x5230;&#x7684;&#xFF0C;&#x4E3A; layout &#x6216;&#x8005;&#x5176;&#x5B83; logback &#x7684;&#x7EC4;&#x4EF6;&#x6DFB;&#x52A0;&#x4E00;&#x4E2A;&#x5C5E;&#x6027;&#xFF0C;&#x8DDF;&#x4E3A;&#x8FD9;&#x4E2A;&#x5C5E;&#x6027;&#x6DFB;&#x52A0;&#x4E00;&#x4E2A; set &#x65B9;&#x6CD5;&#x4E00;&#x6837;&#x7B80;&#x5355;&#x3002;</p>
<p><a href="https://logback.qos.ch/xref/chapters/layouts/MySampleLayout2.html" target="_blank"><code>MySampleLayout2</code></a> &#x7C7B;&#x5305;&#x542B;&#x4E86;&#x4E24;&#x4E2A;&#x5C5E;&#x6027;&#x3002;&#x7B2C;&#x4E00;&#x4E2A;&#x662F;&#x53EF;&#x4EE5;&#x5C06;&#x4E00;&#x4E2A;&#x524D;&#x7F00;&#x6DFB;&#x52A0;&#x5230;&#x8F93;&#x51FA;&#x7684;&#x65E5;&#x5FD7;&#x4E2D;&#x3002;&#x7B2C;&#x4E8C;&#x4E2A;&#x5C5E;&#x6027;&#x53EF;&#x4EE5;&#x7528;&#x6765;&#x9009;&#x62E9;&#x662F;&#x5426;&#x5C55;&#x793A;&#x53D1;&#x9001;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#x7684;&#x7EBF;&#x7A0B;&#x540D;&#x3002;</p>
<p>&#x4E0B;&#x9762;&#x662F; <a href="https://logback.qos.ch/xref/chapters/layouts/MySampleLayout2.html" target="_blank"><code>MySampleLayout2</code></a> &#x7C7B;&#xFF1A;</p>
<pre><code class="lang-java"><span class="hljs-keyword">package</span> chapters.layouts;

<span class="hljs-keyword">import</span> ch.qos.logback.classic.spi.ILoggingEvent;
<span class="hljs-keyword">import</span> ch.qos.logback.core.LayoutBase;

<span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">MySampleLayout2</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">LayoutBase</span>&lt;<span class="hljs-title">ILoggingEvent</span>&gt; </span>{

  String prefix = <span class="hljs-keyword">null</span>;
  <span class="hljs-keyword">boolean</span> printThreadName = <span class="hljs-keyword">true</span>;

  <span class="hljs-function"><span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">setPrefix</span><span class="hljs-params">(String prefix)</span> </span>{
    <span class="hljs-keyword">this</span>.prefix = prefix;
  }

  <span class="hljs-function"><span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">setPrintThreadName</span><span class="hljs-params">(<span class="hljs-keyword">boolean</span> printThreadName)</span> </span>{
    <span class="hljs-keyword">this</span>.printThreadName = printThreadName;
  }

  <span class="hljs-function"><span class="hljs-keyword">public</span> String <span class="hljs-title">doLayout</span><span class="hljs-params">(ILoggingEvent event)</span> </span>{
    StringBuffer sbuf = <span class="hljs-keyword">new</span> StringBuffer(<span class="hljs-number">128</span>);
    <span class="hljs-keyword">if</span> (prefix != <span class="hljs-keyword">null</span>) {
      sbuf.append(prefix + <span class="hljs-string">&quot;: &quot;</span>);
    }
    sbuf.append(event.getTimeStamp() - event.getLoggerContextVO().getBirthTime());
    sbuf.append(<span class="hljs-string">&quot; &quot;</span>);
    sbuf.append(event.getLevel());
    <span class="hljs-keyword">if</span> (printThreadName) {
      sbuf.append(<span class="hljs-string">&quot; [&quot;</span>);
      sbuf.append(event.getThreadName());
      sbuf.append(<span class="hljs-string">&quot;] &quot;</span>);
    } <span class="hljs-keyword">else</span> {
      sbuf.append(<span class="hljs-string">&quot; &quot;</span>);
    }
    sbuf.append(event.getLoggerName());
    sbuf.append(<span class="hljs-string">&quot; - &quot;</span>);
    sbuf.append(event.getFormattedMessage());
    sbuf.append(LINE_SEP);
    <span class="hljs-keyword">return</span> sbuf.toString();
  }
}
</code></pre>
<p>&#x6DFB;&#x52A0;&#x76F8;&#x5E94;&#x7684; set &#x65B9;&#x6CD5;&#x5C31;&#x53EF;&#x4EE5;&#x5F00;&#x542F;&#x5C5E;&#x6027;&#x7684;&#x914D;&#x7F6E;&#x3002;<code>PrintThreadName</code> &#x5C5E;&#x6027;&#x662F; <code>boolean</code> &#x800C;&#x4E0D;&#x662F; <code>String</code> &#x7C7B;&#x578B;&#x3002;&#x5173;&#x4E8E;&#x914D;&#x7F6E; logback &#x7684;&#x8BE6;&#x7EC6;&#x4FE1;&#x606F;&#x8BF7;&#x53C2;&#x89C1;<a href="https://github.com/Volong/logback-chinese-manual/blob/master/03%E7%AC%AC%E4%B8%89%E7%AB%A0%EF%BC%9Alogback%20%E7%9A%84%E9%85%8D%E7%BD%AE.md" target="_blank">&#x7B2C;&#x4E09;&#x7AE0;&#xFF1A;logback &#x7684;&#x914D;&#x7F6E;</a>&#x3002;<a href="https://logback.qos.ch/manual/onJoran.html" target="_blank">&#x7B2C;&#x5341;&#x4E00;&#x7AE0;</a>&#x5C06;&#x4F1A;&#x63D0;&#x4F9B;&#x66F4;&#x8BE6;&#x7EC6;&#x7684;&#x5185;&#x5BB9;&#x3002;&#x4E0B;&#x9762;&#x662F;&#x5173;&#x4E8E; <code>MySampleLayout2</code> &#x7684;&#x76F8;&#x5173;&#x914D;&#x7F6E;&#xFF1A;</p>
<pre><code class="lang-xml"><span class="hljs-tag">&lt;<span class="hljs-name">configuration</span>&gt;</span>

  <span class="hljs-tag">&lt;<span class="hljs-name">appender</span> <span class="hljs-attr">name</span>=<span class="hljs-string">&quot;STDOUT&quot;</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.core.ConsoleAppender&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">encoder</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.core.encoder.LayoutWrappingEncoder&quot;</span>&gt;</span>
      <span class="hljs-tag">&lt;<span class="hljs-name">layout</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;chapters.layouts.MySampleLayout2&quot;</span>&gt;</span> 
        <span class="hljs-tag">&lt;<span class="hljs-name">prefix</span>&gt;</span>MyPrefix<span class="hljs-tag">&lt;/<span class="hljs-name">prefix</span>&gt;</span>
        <span class="hljs-tag">&lt;<span class="hljs-name">printThreadName</span>&gt;</span>false<span class="hljs-tag">&lt;/<span class="hljs-name">printThreadName</span>&gt;</span>
      <span class="hljs-tag">&lt;/<span class="hljs-name">layout</span>&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">encoder</span>&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">appender</span>&gt;</span>

  <span class="hljs-tag">&lt;<span class="hljs-name">root</span> <span class="hljs-attr">level</span>=<span class="hljs-string">&quot;DEBUG&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">appender-ref</span> <span class="hljs-attr">ref</span>=<span class="hljs-string">&quot;STDOUT&quot;</span> /&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">root</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">configuration</span>&gt;</span>
</code></pre>
<h2 id="patternlayout">PatternLayout</h2>
<p>logback &#x914D;&#x5907;&#x4E86;&#x4E00;&#x4E2A;&#x66F4;&#x52A0;&#x7075;&#x6D3B;&#x7684; layout &#x53EB;&#x505A; <a href="https://logback.qos.ch/xref/ch/qos/logback/classic/PatternLayout.html" target="_blank"><code>PatternLayout</code></a>&#x3002;&#x8DDF;&#x6240;&#x6709;&#x7684; layout &#x4E00;&#x6837;&#xFF0C;<code>PatternLayout</code> &#x63A5;&#x6536;&#x4E00;&#x4E2A;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x5E76;&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;&#x4E32;&#x3002;&#x4F46;&#x662F;&#xFF0C;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x8C03;&#x6574; <code>PatternLayout</code> &#x7684;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x6765;&#x8FDB;&#x884C;&#x5B9A;&#x5236;&#x3002;</p>
<p><code>PatternLayout</code> &#x4E2D;&#x7684;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x4E0E; C &#x8BED;&#x8A00;&#x4E2D; <code>printf()</code> &#x65B9;&#x6CD5;&#x4E2D;&#x7684;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x5BC6;&#x5207;&#x76F8;&#x5173;&#x3002;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x7531;&#x5B57;&#x9762;&#x91CF;&#x4E0E;&#x683C;&#x5F0F;&#x63A7;&#x5236;&#x8868;&#x8FBE;&#x5F0F;&#x4E5F;&#x53EB;<em>&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;</em>&#x7EC4;&#x6210;&#x3002;&#x4F60;&#x53EF;&#x4EE5;&#x5728;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x4E2D;&#x81EA;&#x7531;&#x7684;&#x63D2;&#x5165;&#x5B57;&#x9762;&#x91CF;&#x3002;&#x6BCF;&#x4E00;&#x4E2A;&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;&#x7531;&#x4E00;&#x4E2A;&#x767E;&#x5206;&#x53F7;&#x5F00;&#x59CB; &apos;%&apos;&#xFF0C;&#x540E;&#x9762;&#x8DDF;&#x968F;&#x53EF;&#x9009;&#x7684;<em>&#x683C;&#x5F0F;&#x4FEE;&#x6539;&#x5668;</em>&#xFF0C;&#x4EE5;&#x53CA;&#x7528;&#x7EFC;&#x62EC;&#x53F7;&#x62EC;&#x8D77;&#x6765;&#x7684;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x4E0E;&#x53EF;&#x9009;&#x7684;&#x53C2;&#x6570;&#x3002;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x9700;&#x8981;&#x8F6C;&#x6362;&#x7684;&#x5B57;&#x6BB5;&#x3002;&#x5982;&#xFF1A;logger &#x7684;&#x540D;&#x5B57;&#xFF0C;&#x65E5;&#x5FD7;&#x7EA7;&#x522B;&#xFF0C;&#x65E5;&#x671F;&#x4EE5;&#x53CA;&#x7EBF;&#x7A0B;&#x540D;&#x3002;&#x683C;&#x5F0F;&#x4FEE;&#x6539;&#x5668;&#x63A7;&#x5236;&#x5B57;&#x6BB5;&#x7684;&#x5BBD;&#x5EA6;&#xFF0C;&#x95F4;&#x8DDD;&#x4EE5;&#x53CA;&#x5DE6;&#x53F3;&#x5BF9;&#x9F50;&#x3002;</p>
<p>&#x6B63;&#x5982;&#x6211;&#x4EEC;&#x5DF2;&#x7ECF;&#x5728;&#x5176;&#x5B83;&#x5730;&#x65B9;&#x63D0;&#x5230;&#x8FC7;&#x7684;&#xFF0C;<code>FileAppender</code> &#x53CA;&#x5176;&#x5B50;&#x7C7B;&#x9700;&#x8981;&#x4E00;&#x4E2A; encoder&#x3002;&#x56E0;&#x4E3A;&#xFF0C;&#x5F53;&#x5C06; <code>FileAppender</code> &#x53CA;&#x5176;&#x5B50;&#x7C7B;&#x4E0E; <code>PatternLayout</code> &#x7ED3;&#x5408;&#x4F7F;&#x7528;&#x65F6;&#xFF0C;<code>PatternLayout</code> &#x5FC5;&#x987B;&#x7528; encoder &#x5305;&#x88F9;&#x8D77;&#x6765;&#x3002;&#x9274;&#x4E8E; <code>FileAppender/PatternLayout</code> &#x7ED3;&#x5408;&#x4F7F;&#x7528;&#x5F88;&#x5E38;&#x89C1;&#xFF0C;&#x56E0;&#x6B64; logback &#x5355;&#x72EC;&#x8BBE;&#x8BA1;&#x4E86;&#x4E00;&#x4E2A;&#x540D;&#x53EB; <code>PatternLayoutEncoder</code> &#x7684; encoder&#xFF0C;&#x5305;&#x88F9;&#x4E86;&#x4E00;&#x4E2A; <code>PatternLayout</code>&#xFF0C;&#x56E0;&#x6B64;&#x5B83;&#x53EF;&#x4EE5;&#x88AB;&#x5F53;&#x4F5C;&#x4E00;&#x4E2A; encoder&#x3002;&#x4E0B;&#x9762;&#x662F;&#x901A;&#x8FC7;&#x4EE3;&#x7801;&#x914D;&#x7F6E; <code>ConsoleAppender</code> &#x4E0E; <code>PatternLayoutEncoder</code> &#x4F7F;&#x7528;&#x7684;&#x4F8B;&#x5B50;&#xFF1A;</p>
<blockquote>
<p>  Example: <a href="https://logback.qos.ch/xref/chapters/layouts/PatternSample.html" target="_blank">PatternSample.java</a></p>
</blockquote>
<pre><code class="lang-java"><span class="hljs-keyword">package</span> chapters.layouts;

<span class="hljs-keyword">import</span> org.slf4j.LoggerFactory;

<span class="hljs-keyword">import</span> ch.qos.logback.classic.Logger;
<span class="hljs-keyword">import</span> ch.qos.logback.classic.LoggerContext;
<span class="hljs-keyword">import</span> ch.qos.logback.classic.encoder.PatternLayoutEncoder;
<span class="hljs-keyword">import</span> ch.qos.logback.classic.spi.ILoggingEvent;
<span class="hljs-keyword">import</span> ch.qos.logback.core.ConsoleAppender;

<span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">PatternSample</span> </span>{

  <span class="hljs-function"><span class="hljs-keyword">static</span> <span class="hljs-keyword">public</span> <span class="hljs-keyword">void</span> <span class="hljs-title">main</span><span class="hljs-params">(String[] args)</span> <span class="hljs-keyword">throws</span> Exception </span>{
    Logger rootLogger = (Logger)LoggerFactory.getLogger(Logger.ROOT_LOGGER_NAME);
    LoggerContext loggerContext = rootLogger.getLoggerContext();
    <span class="hljs-comment">// we are not interested in auto-configuration</span>
    loggerContext.reset();

    PatternLayoutEncoder encoder = <span class="hljs-keyword">new</span> PatternLayoutEncoder();
    encoder.setContext(loggerContext);
    encoder.setPattern(<span class="hljs-string">&quot;%-5level [%thread]: %message%n&quot;</span>);
    encoder.start();

    ConsoleAppender&lt;ILoggingEvent&gt; appender = <span class="hljs-keyword">new</span> ConsoleAppender&lt;ILoggingEvent&gt;();
    appender.setContext(loggerContext);
    appender.setEncoder(encoder); 
    appender.start();

    rootLogger.addAppender(appender);

    rootLogger.debug(<span class="hljs-string">&quot;Message 1&quot;</span>); 
    rootLogger.warn(<span class="hljs-string">&quot;Message 2&quot;</span>);
  } 
}
</code></pre>
<p>&#x5728;&#x4E0A;&#x9762;&#x8FD9;&#x4E2A;&#x4F8B;&#x5B50;&#x4E2D;&#xFF0C;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x88AB;&#x8BBE;&#x7F6E;&#x4E3A; &quot;<strong>%-5level [%thread]: %message%n</strong> &quot;&#xFF0C;&#x5173;&#x4E8E; logback &#x4E2D;&#x7B80;&#x77ED;&#x7684;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x5C06;&#x4F1A;&#x5F88;&#x5FEB;&#x7ED9;&#x51FA;&#x3002;&#x8FD0;&#x884C; <code>PatternSample</code>&#xFF1A;</p>
<pre><code class="lang-bash">java java chapters.layouts.PatternSample
</code></pre>
<p>&#x5C06;&#x4F1A;&#x8F93;&#x51FA;&#x5982;&#x4E0B;&#x4FE1;&#x606F;&#xFF1A;</p>
<pre><code class="lang-java">DEBUG [main]: Message <span class="hljs-number">1</span> 
WARN  [main]: Message <span class="hljs-number">2</span>
</code></pre>
<p>&#x5728;&#x8F6C;&#x6362;&#x6A21;&#x5F0F; <strong>&quot;%-5level [%thread]: %message%n&quot;</strong> &#x4E2D;&#xFF0C;&#x5B57;&#x9762;&#x91CF;&#x4E0E;&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;&#x4E4B;&#x95F4;&#x6CA1;&#x6709;&#x660E;&#x663E;&#x7684;&#x5206;&#x9694;&#x7B26;&#x3002;&#x5F53;&#x5BF9;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x8FDB;&#x884C;&#x89E3;&#x6790;&#x7684;&#x65F6;&#x5019;&#xFF0C;<code>PatternLayout</code> &#x6709;&#x80FD;&#x529B;&#x5BF9;&#x5B57;&#x9762;&#x91CF; (&#x7A7A;&#x683C;&#x7B26;&#xFF0C;&#x65B9;&#x62EC;&#x53F7;&#xFF0C;&#x5192;&#x53F7;) &#x548C; &#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;&#x8FDB;&#x884C;&#x533A;&#x5206;&#x3002;&#x5728;&#x4E0A;&#x9762;&#x7684;&#x4F8B;&#x5B50;&#x4E2D;&#xFF0C;&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26; %-5level &#x8868;&#x793A;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x7684;&#x7EA7;&#x522B;&#x7684;&#x5B57;&#x7B26;&#x5E94;&#x8BE5;&#x5411;&#x5DE6;&#x5BF9;&#x9F50;&#xFF0C;&#x4FDD;&#x6301;&#x4E94;&#x4E2A;&#x5B57;&#x7B26;&#x7684;&#x5BBD;&#x5EA6;&#x3002;&#x5177;&#x4F53;&#x7684;&#x8F6C;&#x6362;&#x683C;&#x5F0F;&#x5C06;&#x4F1A;&#x5728;&#x4E0B;&#x9762;&#x4ECB;&#x7ECD;&#x3002;</p>
<p>&#x5728; <code>PatternLayout</code> &#x4E2D;&#xFF0C;&#x62EC;&#x53F7;&#x7528;&#x4E8E;&#x5BF9;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x8FDB;&#x884C;&#x5206;&#x7EC4;&#x3002;<strong>&apos;(&apos; &#x4E0E; &apos;)&apos; &#x6709;&#x7279;&#x6B8A;&#x7684;&#x542B;&#x4E49;&#xFF0C;&#x56E0;&#x6B64;&#x5982;&#x679C;&#x60F3;&#x7528;&#x4F5C;&#x5B57;&#x9762;&#x91CF;&#xFF0C;&#x9700;&#x8981;&#x8FDB;&#x884C;&#x7279;&#x6B8A;&#x7684;&#x8F6C;&#x4E49;</strong>&#x3002;&#x5706;&#x62EC;&#x53F7;&#x7684;&#x7279;&#x6B8A;&#x542B;&#x4E49;&#x5C06;&#x5728;<a href="https://logback.qos.ch/manual/layouts.html#Parentheses" target="_blank">&#x4E0B;&#x9762;</a> &#x8FDB;&#x884C;&#x8BE6;&#x7EC6;&#x7684;&#x4ECB;&#x7ECD;&#x3002;</p>
<p>&#x4E4B;&#x524D;&#x63D0;&#x5230;&#x8FC7;&#xFF0C;&#x7279;&#x5B9A;&#x7684;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x82B1;&#x62EC;&#x53F7;&#x6307;&#x5B9A;&#x53EF;&#x9009;&#x7684;&#x53C2;&#x6570;&#x3002;&#x4E00;&#x4E2A;&#x7B80;&#x5355;&#x7684;&#x53EF;&#x9009;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x53EF;&#x4EE5;&#x662F; %logger{10}&#x3002;&#x5728;&#x8FD9;&#x91CC; &quot;logger&quot; &#x5C31;&#x662F;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#xFF0C;10 &#x5C31;&#x662F;&#x53EF;&#x9009;&#x53C2;&#x6570;&#x3002;&#x53EF;&#x9009;&#x53C2;&#x5C06;&#x5728;<a href="https://logback.qos.ch/manual/layouts.html#cwOptions" target="_blank">&#x4E0B;&#x9762;</a>&#x8BE6;&#x7EC6;&#x4ECB;&#x7ECD;&#x3002;</p>
<p>&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x4E0E;&#x5B83;&#x4EEC;&#x7684;&#x53EF;&#x9009;&#x53C2;&#x6570;&#x5728;&#x4E0B;&#x9762;&#x7684;&#x8868;&#x683C;&#x4E2D;&#x8FDB;&#x884C;&#x8BE6;&#x7EC6;&#x53D9;&#x8FF0;&#x3002;&#x5F53;&#x591A;&#x4E2A;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x5728;&#x540C;&#x4E00;&#x4E2A;&#x5355;&#x5143;&#x683C;&#x4E2D;&#x88AB;&#x5217;&#x51FA;&#x6765;&#xFF0C;&#x5B83;&#x4EEC;&#x88AB;&#x5F53;&#x4F5C;&#x522B;&#x540D;&#x6765;&#x8003;&#x8651;&#x3002;</p>
<table>
<thead>
<tr>
<th>&#x8F6C;&#x6362;&#x5B57;&#x7B26;</th>
<th>&#x6548;&#x679C;</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>c</strong>{<em>length</em>}<br><strong>lo</strong>{<em>length</em>}<br><strong>logger</strong>{<em>length</em>}</td>
<td>&#x8F93;&#x51FA; logger &#x7684;&#x540D;&#x5B57;&#x4F5C;&#x4E3A;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x7684;&#x6765;&#x6E90;&#x3002;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x63A5;&#x6536;&#x4E00;&#x4E2A;&#x4F5C;&#x4E3A;&#x5B83;&#x7684;&#x7B2C;&#x4E00;&#x4E2A;&#x4E5F;&#x662F;&#x4E3A;&#x4E00;&#x4E2A;&#x53C2;&#x6570;&#x3002;&#x8F6C;&#x6362;&#x5668;&#x7684;&#x7B80;&#x5199;&#x7B97;&#x6CD5;&#x5C06;&#x4F1A;&#x7F29;&#x77ED; logger &#x7684;&#x540D;&#x5B57;&#xFF0C;&#x4F46;&#x662F;&#x901A;&#x8FC7;&#x4E0D;&#x4F1A;&#x4E22;&#x5931;&#x91CD;&#x8981;&#x7684;&#x4FE1;&#x606F;&#x3002;&#x8BBE;&#x7F6E; length &#x7684;&#x503C;&#x4E3A; 0 &#x662F;&#x4E00;&#x4E2A;&#x4F8B;&#x5916;&#x3002;&#x5B83;&#x5C06;&#x4F1A;&#x5BFC;&#x81F4;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x8FD4;&#x56DE; logger &#x540D;&#x5B57;&#x4E2D;&#x6700;&#x53F3;&#x8FB9;&#x7684;&#x70B9;&#x53F3;&#x8FB9;&#x7684;&#x5B57;&#x7B26;&#x3002;&#x4E0B;&#x9762;&#x7684;&#x8868;&#x683C;&#x63D0;&#x4F9B;&#x4E86;&#x4E00;&#x4E2A;&#x793A;&#x4F8B;&#xFF1A;<br><table><tr><th>&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;</th><th>logger&#x7684;&#x540D;&#x5B57;</th><th>&#x7ED3;&#x679C;</th></tr><tr><td>%logger</td><td>mainPackage.sub.sample.Bar</td><td>mainPackage.sub.sample.Bar</td></tr><tr><td>%logger{0}</td><td>mainPackage.sub.sample.Bar</td><td>Bar</td></tr><tr><td>%logger{5}</td><td>mainPackage.sub.sample.Bar</td><td>m.s.s.Bar</td></tr><tr><td>%logger{10}</td><td>mainPackage.sub.sample.Bar</td><td>m.s.s.Bar</td></tr><tr><td>%logger{15}</td><td>mainPackage.sub.sample.Bar</td><td>m.s.sample.Bar</td></tr><tr><td>%logger{16}</td><td>mainPackage.sub.sample.Bar</td><td>m.sub.sample.Bar</td></tr><tr><td>%logger{26}</td><td>mainPackage.sub.sample.Bar</td><td>mainPackage.sub.sample.Bar</td></tr></table>logger &#x540D;&#x5B57;&#x6700;&#x53F3;&#x8FB9;&#x7684;&#x90E8;&#x5206;&#x6C38;&#x8FDC;&#x4E0D;&#x4F1A;&#x88AB;&#x7B80;&#x5199;&#xFF0C;&#x5373;&#x4F7F;&#x5B83;&#x7684;&#x957F;&#x5EA6;&#x6BD4; <em>length</em> &#x7684;&#x503C;&#x8981;&#x5927;&#x3002;&#x5176;&#x5B83;&#x7684;&#x90E8;&#x5206;&#x53EF;&#x80FD;&#x4F1A;&#x88AB;&#x7F29;&#x77ED;&#x4E3A;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;&#xFF0C;&#x4F46;&#x662F;&#x6C38;&#x4E0D;&#x4F1A;&#x88AB;&#x79FB;&#x9664;&#x3002;<br></td>
</tr>
<tr>
<td><strong>C</strong>{<em>length</em>}  <br><strong>class</strong>{<em>length</em>}</td>
<td>&#x8F93;&#x51FA;&#x53D1;&#x51FA;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#x7684;&#x7C7B;&#x7684;&#x5168;&#x9650;&#x5B9A;&#x540D;&#x79F0;&#x3002;<br>&#x8DDF; <em>%logger%</em> &#x8F6C;&#x6362;&#x7B26;&#x4E00;&#x6837;&#xFF0C;&#x5B83;&#x4E5F;&#x53EF;&#x4EE5;&#x63A5;&#x6536;&#x4E00;&#x4E2A;&#x6574;&#x578B;&#x7684;&#x53EF;&#x9009;&#x53C2;&#x6570;&#x53BB;&#x7F29;&#x77ED;&#x7C7B;&#x540D;&#x3002;0 &#x8868;&#x793A;&#x7279;&#x6B8A;&#x542B;&#x4E49;&#xFF0C;&#x5728;&#x6253;&#x5370;&#x7C7B;&#x540D;&#x65F6;&#x5C06;&#x4E0D;&#x4F1A;&#x8F93;&#x51FA;&#x5305;&#x7684;&#x524D;&#x7F00;&#x540D;&#x3002;&#x9ED8;&#x8BA4;&#x8868;&#x793A;&#x6253;&#x5370;&#x7C7B;&#x7684;&#x5168;&#x9650;&#x5B9A;&#x540D;&#x3002;<br>&#x751F;&#x6210;&#x8C03;&#x7528;&#x8005;&#x7C7B;&#x7684;&#x4FE1;&#x606F;&#x5E76;&#x4E0D;&#x662F;&#x7279;&#x522B;&#x5FEB;&#x3002;&#x56E0;&#x6B64;&#xFF0C;&#x5E94;&#x8BE5;&#x907F;&#x514D;&#x4F7F;&#x7528;&#xFF0C;&#x9664;&#x975E;&#x6267;&#x884C;&#x901F;&#x5EA6;&#x4E0D;&#x662F;&#x95EE;&#x9898;&#x3002;</td>
</tr>
<tr>
<td><strong>contextName</strong><br><strong>cn</strong></td>
<td>&#x8F93;&#x51FA;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x9644;&#x52A0;&#x5230;&#x7684; logger &#x4E0A;&#x4E0B;&#x6587;&#x7684;&#x540D;&#x5B57;&#x3002;</td>
</tr>
<tr>
<td><strong>d</strong>{<em>pattern</em>}  <strong>date</strong>{<em>pattern</em>}  <strong>d</strong>{<em>pattern</em>, <em>timezone</em>}  <strong>date</strong>{<em>pattern</em>, <em>timezone</em>}</td>
<td>&#x7528;&#x4E8E;&#x8F93;&#x51FA;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x7684;&#x65E5;&#x671F;&#x3002;&#x65E5;&#x671F;&#x8F6C;&#x6362;&#x7B26;&#x5141;&#x8BB8;&#x63A5;&#x6536;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;&#x4E32;&#x4F5C;&#x4E3A;&#x53C2;&#x6570;&#x3002;&#x5B57;&#x7B26;&#x4E32;&#x7684;&#x8BED;&#x6CD5;&#x4E0E; <a href="https://docs.oracle.com/javase/8/docs/api/java/text/SimpleDateFormat.html" target="_blank">SimpleDateFormat</a> &#x4E2D;&#x7684;&#x683C;&#x5F0F;&#x5B8C;&#x5168;&#x517C;&#x5BB9;&#x3002;<br>&#x4F60;&#x53EF;&#x4EE5;&#x6307;&#x5B9A; &quot;ISO8601&quot; &#x6765;&#x8868;&#x793A;&#x5C06;&#x65E5;&#x671F;&#x683C;&#x5F0F;&#x4E3A; ISO8601 &#x7C7B;&#x578B;&#x3002;&#x5982;&#x679C;&#x6CA1;&#x6709;&#x6307;&#x5B9A;&#x65E5;&#x671F;&#x683C;&#x5F0F;&#xFF0C;&#x90A3;&#x4E48; %date &#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x9ED8;&#x8BA4;&#x4E3A; <a href="https://en.wikipedia.org/wiki/ISO_8601" target="_blank">ISO860 &#x7C7B;&#x578B;</a>&#x3002;<br>&#x8FD9;&#x91CC;&#x6709;&#x4E00;&#x4E2A;&#x4F8B;&#x5B50;&#x3002;&#x5B83;&#x5047;&#x8BBE;&#x5F53;&#x524D;&#x65F6;&#x95F4;&#x4E3A; 2006.10.20 &#x661F;&#x671F;&#x4E94;&#xFF0C;&#x4F5C;&#x8005;&#x521A;&#x521A;&#x5403;&#x5B8C;&#x996D;&#x51C6;&#x5907;&#x5199;&#x8FD9;&#x7BC7;&#x6587;&#x6863;&#x3002;<br><table><tr><th>&#x8F6C;&#x6362;&#x6A21;&#x5F0F;</th><th>&#x7ED3;&#x679C;</th></tr><tr><td>%d</td><td>2006-10-20 14:06:49,812</td></tr><tr><td>%date</td><td>2006-10-20 14:06:49,812</td></tr><tr><td>%date{ISO8601}</td><td>2006-10-20 14:06:49,812</td></tr><tr><td>%date{HH:mm:ss.SSS}</td><td>14:06:49.812</td></tr><tr><td>%date{dd MMM yyyy;HH:mm:ss.SSS}</td><td>20 oct. 2006;14:06:49.812</td></tr></table><br>&#x7B2C;&#x4E8C;&#x4E2A;&#x53C2;&#x6570;&#x7528;&#x4E8E;&#x6307;&#x5B9A;&#x65F6;&#x533A;&#x3002;&#x4F8B;&#x5982;&#xFF0C; &apos;%date{HH:mm:ss.SSS, Australia/Perth}&apos; &#x5C06;&#x4F1A;&#x6253;&#x5370;&#x4E16;&#x754C;&#x4E0A;&#x6700;&#x5B64;&#x7ACB;&#x7684;&#x57CE;&#x5E02;&#xFF0C;&#x6FB3;&#x5927;&#x5229;&#x4E9A;&#x4F69;&#x65AF;&#x6240;&#x5728;&#x65F6;&#x533A;&#x7684;&#x65E5;&#x671F;&#x3002;&#x5982;&#x679C;&#x6CA1;&#x6709;&#x6307;&#x5B9A;&#x65F6;&#x533A;&#x53C2;&#x6570;&#xFF0C;&#x5219;&#x9ED8;&#x8BA4;&#x4F7F;&#x7528; Java &#x5E73;&#x53F0;&#x6240;&#x5728;&#x4E3B;&#x673A;&#x7684;&#x65F6;&#x533A;&#x3002;&#x5982;&#x679C;&#x6307;&#x5B9A;&#x7684;&#x65F6;&#x533A;&#x4E0D;&#x80FD;&#x8BC6;&#x522B;&#x6216;&#x8005;&#x62FC;&#x5199;&#x9519;&#x8BEF;&#xFF0C;&#x5219; <a href="http://docs.oracle.com/javase/6/docs/api/java/util/TimeZone.html#getTimeZone(java.lang.String" target="_blank">TimeZone.getTimeZone(String)</a>) &#x65B9;&#x6CD5;&#x4F1A;&#x6307;&#x5B9A;&#x65F6;&#x533A;&#x4E3A; GMT&#x3002;<br><code>&#x5E38;&#x89C1;&#x9519;&#x8BEF;&#xFF1A;</code> &#x5BF9;&#x4E8E; <code>HH:mm:ss,SSS</code> &#x6A21;&#x5F0F;&#xFF0C;&#x9017;&#x53F7;&#x4F1A;&#x88AB;&#x89E3;&#x6790;&#x4E3A;&#x5206;&#x9694;&#x7B26;&#xFF0C;&#x6240;&#x4EE5;&#x6700;&#x7EC8;&#x4F1A;&#x88AB;&#x89E3;&#x6790;&#x4E3A; <code>HH:mm:ss</code>&#xFF0C;<code>SSS</code> &#x4F1A;&#x88AB;&#x5F53;&#x4F5C;&#x65F6;&#x533A;&#x3002;&#x5982;&#x679C;&#x4F60;&#x60F3;&#x5728;&#x65E5;&#x671F;&#x6A21;&#x5F0F;&#x4E2D;&#x4F7F;&#x7528;&#x9017;&#x53F7;&#xFF0C;&#x90A3;&#x4E48;&#x4F60;&#x53EF;&#x4EE5;&#x8FD9;&#x6837;&#x4F7F;&#x7528;&#xFF0C;%date{<strong>&quot;</strong>HH:mm:ss,SSS<strong>&quot;</strong>}  &#x7528;&#x53CC;&#x5F15;&#x53F7;&#x5C06;&#x65E5;&#x671F;&#x6A21;&#x5F0F;&#x5305;&#x88F9;&#x8D77;&#x6765;&#x3002;</td>
</tr>
<tr>
<td><strong>F / file</strong></td>
<td>&#x8F93;&#x51FA;&#x53D1;&#x51FA;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#x7684; Java &#x6E90;&#x6587;&#x4EF6;&#x540D;&#x3002;<br>&#x7531;&#x4E8E;&#x751F;&#x6210;&#x6587;&#x4EF6;&#x7684;&#x4FE1;&#x606F;&#x4E0D;&#x662F;&#x7279;&#x522B;&#x5FEB;&#xFF0C;&#x56E0;&#x6B64;&#xFF0C;&#x5E94;&#x8BE5;&#x907F;&#x514D;&#x4F7F;&#x7528;&#xFF0C;&#x9664;&#x975E;&#x901F;&#x5EA6;&#x4E0D;&#x662F;&#x95EE;&#x9898;&#x3002;</td>
</tr>
<tr>
<td><strong>caller{depth}</strong><br><strong>caller{depthStart..depthEnd}</strong><br><strong>caller{depth, evaluator-1, ... evaluator-n}</strong><br><strong>caller{depthStart..depthEnd, evaluator-1, ... evaluator-n}</strong></td>
<td>&#x8F93;&#x51FA;&#x751F;&#x6210;&#x65E5;&#x5FD7;&#x7684;&#x8C03;&#x7528;&#x8005;&#x6240;&#x5728;&#x7684;&#x4F4D;&#x7F6E;&#x4FE1;&#x606F;&#x3002;<br>&#x4F4D;&#x7F6E;&#x4FE1;&#x606F;&#x4F9D;&#x8D56; JVM &#x7684;&#x5B9E;&#x73B0;&#xFF0C;&#x4F46;&#x662F;&#x901A;&#x5E38;&#x7531;&#x8C03;&#x7528;&#x65B9;&#x6CD5;&#x7684;&#x5168;&#x9650;&#x5B9A;&#x540D;&#x4EE5;&#x53CA;&#x8C03;&#x7528;&#x8005;&#x7684;&#x6765;&#x6E90;&#x7EC4;&#x6210;&#x3002;&#x4EE5;&#x53CA;&#x7531;&#x5706;&#x62EC;&#x53F7;&#x62EC;&#x8D77;&#x6765;&#x7684;&#x6587;&#x4EF6;&#x540D;&#x4E0E;&#x884C;&#x53F7;&#x3002;<br><em>caller</em> &#x8F6C;&#x6362;&#x7B26;&#x8FD8;&#x53EF;&#x4EE5;&#x63A5;&#x6536;&#x4E00;&#x4E2A;&#x6574;&#x5F62;&#x7684;&#x53C2;&#x6570;&#xFF0C;&#x7528;&#x6765;&#x914D;&#x7F6E;&#x5C55;&#x793A;&#x4FE1;&#x606F;&#x7684;&#x6DF1;&#x5EA6;&#x3002;<br>&#x4F8B;&#x5982;&#xFF0C;<strong>%caller{2}</strong> &#x4F1A;&#x5C55;&#x793A;&#x5982;&#x4E0B;&#x7684;&#x4FE1;&#x606F;&#xFF1A;<br><pre style="background-color:#eaecef">0    [main] DEBUG - logging statement<br>Caller+0   at mainPackage.sub.sample.Bar.sampleMethodName(Bar.java:22)<br>Caller+1   at mainPackage.sub.sample.Bar.createLoggingRequest(Bar.java:17)</pre> <strong>%caller{3}</strong>  &#x4F1A;&#x5C55;&#x793A;&#x5982;&#x4E0B;&#x4FE1;&#x606F;&#xFF1A;<br><pre><span style="background-color:#eaecef">16   [main] DEBUG - logging statement <br>Caller+0   at mainPackage.sub.sample.Bar.sampleMethodName(Bar.java:22) <br>Caller+1   at mainPackage.sub.sample.Bar.createLoggingRequest(Bar.java:17) <br>Caller+2   at mainPackage.ConfigTester.main(ConfigTester.java:38) </span></pre><br><em>caller</em> &#x8F6C;&#x6362;&#x7B26;&#x8FD8;&#x53EF;&#x4EE5;&#x63A5;&#x6536;&#x4E00;&#x4E2A;&#x8303;&#x56F4;&#x7528;&#x6765;&#x5C55;&#x793A;&#x6DF1;&#x5EA6;&#x5728;&#x8FD9;&#x4E2A;&#x8303;&#x56F4;&#x5185;&#x7684;&#x4FE1;&#x606F;&#x3002;<br>&#x4F8B;&#x5982;&#xFF0C;<strong>%caller{1..2}</strong> &#x4F1A;&#x5C55;&#x793A;&#x5982;&#x4E0B;&#x4FE1;&#x606F;&#xFF1A;<br><pre>[main] DEBUG - logging statement <br>Caller+0   at mainPackage.sub.sample.Bar.createLoggingRequest(Bar.java:17)</pre><br>&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x8FD8;&#x53EF;&#x4EE5;&#x63A5;&#x6536;&#x4E00;&#x4E2A; evaluator&#xFF0C;&#x5728;&#x8BA1;&#x7B97;&#x8C03;&#x7528;&#x8005;&#x6570;&#x636E;&#x4E4B;&#x524D;&#x901A;&#x8FC7;&#x6307;&#x5B9A;&#x7684;&#x6807;&#x51C6;&#x5BF9;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x8FDB;&#x884C;&#x6D4B;&#x9A8C;&#x3002;&#x4F8B;&#x5982;&#xFF0C;<strong>%caller{3, CALLER_DISPLAY_EVAL}</strong> &#x4F1A;&#x5728; <em>CALLER_DISPLAY_EVAL</em> &#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x80AF;&#x5B9A;&#x7684;&#x7B54;&#x6848;&#xFF0C;&#x624D;&#x4F1A;&#x663E;&#x793A;&#x4E09;&#x884C;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x3002;<br>&#x5C06;&#x5728;&#x4E0B;&#x9762;&#x8BE6;&#x7EC6;&#x53D9;&#x8FF0; evaluator&#x3002;</td>
</tr>
<tr>
<td><strong>L / line</strong></td>
<td>&#x8F93;&#x51FA;&#x53D1;&#x51FA;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#x6240;&#x5728;&#x7684;&#x884C;&#x53F7;&#x3002;<br>&#x751F;&#x6210;&#x884C;&#x53F7;&#x4E0D;&#x662F;&#x7279;&#x522B;&#x5FEB;&#x3002;&#x56E0;&#x6B64;&#xFF0C;&#x4E0D;&#x5EFA;&#x8BAE;&#x4F7F;&#x7528;&#xFF0C;&#x9664;&#x975E;&#x751F;&#x6210;&#x901F;&#x5EA6;&#x4E0D;&#x662F;&#x95EE;&#x9898;&#x3002;</td>
</tr>
<tr>
<td><strong>m / msg / message</strong></td>
<td>&#x8F93;&#x51FA;&#x4E0E;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x76F8;&#x5173;&#x8054;&#x7684;&#xFF0C;&#x7531;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x63D0;&#x4F9B;&#x7684;&#x65E5;&#x5FD7;&#x4FE1;&#x606F;&#x3002;</td>
</tr>
<tr>
<td><strong>M / method</strong></td>
<td>&#x8F93;&#x51FA;&#x53D1;&#x51FA;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#x7684;&#x65B9;&#x6CD5;&#x540D;&#x3002;<br>&#x751F;&#x6210;&#x65B9;&#x6CD5;&#x540D;&#x4E0D;&#x662F;&#x7279;&#x522B;&#x5FEB;&#xFF0C;&#x56E0;&#x6B64;&#xFF0C;&#x5E94;&#x8BE5;&#x907F;&#x514D;&#x4F7F;&#x7528;&#xFF0C;&#x9664;&#x975E;&#x751F;&#x6210;&#x901F;&#x5EA6;&#x4E0D;&#x662F;&#x95EE;&#x9898;&#x3002;</td>
</tr>
<tr>
<td><strong>n</strong></td>
<td>&#x8F93;&#x51FA;&#x5E73;&#x53F0;&#x6240;&#x4F9D;&#x8D56;&#x7684;&#x884C;&#x5206;&#x5272;&#x5B57;&#x7B26;&#x3002;<br>&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x63D0;&#x4F9B;&#x4E86;&#x50CF; &quot;\n&quot; &#x6216; &quot;\r\n&quot; &#x4E00;&#x6837;&#x7684;&#x8F6C;&#x6362;&#x6548;&#x679C;&#x3002;&#x56E0;&#x6B64;&#x6307;&#x5B9A;&#x884C;&#x5206;&#x9694;&#x7B26;&#x5B83;&#x662F;&#x9996;&#x9009;&#x7684;&#x6307;&#x5B9A;&#x65B9;&#x5F0F;&#x3002;</td>
</tr>
<tr>
<td><strong>p / le / level</strong></td>
<td>&#x8F93;&#x51FA;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x7684;&#x7EA7;&#x522B;&#x3002;</td>
</tr>
<tr>
<td><strong>r / relative</strong></td>
<td>&#x8F93;&#x51FA;&#x5E94;&#x7528;&#x7A0B;&#x5E8F;&#x542F;&#x52A8;&#x5230;&#x521B;&#x5EFA;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x6240;&#x82B1;&#x8D39;&#x7684;&#x6BEB;&#x79D2;&#x6570;</td>
</tr>
<tr>
<td><strong>t / thread</strong></td>
<td>&#x8F93;&#x51FA;&#x751F;&#x6210;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x7684;&#x7EBF;&#x7A0B;&#x540D;&#x3002;</td>
</tr>
<tr>
<td><strong>X</strong>{<em>key:-defaultVal</em>}<br>  <strong>mdc</strong>{<em>key:-defaultVal</em>}</td>
<td>&#x8F93;&#x51FA;&#x751F;&#x6210;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x7684;&#x7EBF;&#x7A0B;&#x7684; MDC (mapped diagnostic context)&#x3002;<br>&#x5982;&#x679C; <strong>MDC</strong> &#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x540E;&#x9762;&#x8DDF;&#x7740;&#x7528;&#x82B1;&#x62EC;&#x53F7;&#x62EC;&#x8D77;&#x6765;&#x7684; kye&#xFF0C;&#x4F8B; <strong>%MDC{userid}</strong>&#xFF0C;&#x90A3;&#x4E48; &apos;userid&apos; &#x6240;&#x5BF9;&#x5E94; MDC &#x7684;&#x503C;&#x5C06;&#x4F1A;&#x8F93;&#x51FA;&#x3002;&#x5982;&#x679C;&#x8BE5;&#x503C;&#x4E3A; null&#xFF0C;&#x90A3;&#x4E48;&#x901A;&#x8FC7; :- &#x6307;&#x5B9A;&#x7684;<a href="https://github.com/Volong/logback-chinese-manual/blob/master/03%E7%AC%AC%E4%B8%89%E7%AB%A0%EF%BC%9Alogback%20%E7%9A%84%E9%85%8D%E7%BD%AE.md#%E5%8F%98%E9%87%8F%E7%9A%84%E9%BB%98%E8%AE%A4%E5%80%BC" target="_blank">&#x9ED8;&#x8BA4;&#x503C;</a> &#x5C06;&#x4F1A;&#x8F93;&#x51FA;&#x3002;&#x5982;&#x679C;&#x6CA1;&#x6709;&#x6307;&#x5B9A;&#x9ED8;&#x8BA4;&#x503C;&#xFF0C;&#x90A3;&#x4E48;&#x5C06;&#x4F1A;&#x8F93;&#x51FA;&#x7A7A;&#x5B57;&#x7B26;&#x4E32;&#x3002;<br>&#x5982;&#x679C;&#x6CA1;&#x6709;&#x6307;&#x5B9A;&#x7684; key&#xFF0C;&#x90A3;&#x4E48; MDC &#x7684;&#x6574;&#x4E2A;&#x5185;&#x5BB9;&#x5C06;&#x4F1A;&#x4EE5; &quot;key1=val1, key2=val2&quot; &#x7684;&#x683C;&#x5F0F;&#x8F93;&#x51FA;&#x3002;<br>&#x67E5;&#x8BE6;&#x60C5;&#x8BF7;&#x89C1; <a href="https://logback.qos.ch/manual/mdc.html" target="_blank">&#x7B2C;&#x516B;&#x7AE0;</a></td>
</tr>
<tr>
<td><strong>ex</strong>{<em>depth</em>}  <strong>exception</strong>{<em>depth</em>}  <strong>throwable</strong>{<em>depth</em>}   <strong>ex</strong>{depth, evaluator-1, ..., evaluator-n}  <strong>exception</strong>{depth, evaluator-1, ..., evaluator-n}  <strong>throwable</strong>{depth, evaluator-1, ..., evaluator-n}</td>
<td>&#x8F93;&#x51FA;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x76F8;&#x5173;&#x7684;&#x5806;&#x6808;&#x4FE1;&#x606F;&#xFF0C;&#x9ED8;&#x8BA4;&#x60C5;&#x51B5;&#x4E0B;&#x4F1A;&#x8F93;&#x51FA;&#x5168;&#x90E8;&#x7684;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x3002;<br> <em>throwable</em> &#x8F6C;&#x6362;&#x8BCD;&#x53EF;&#x4EE5;&#x63A5;&#x6536;&#x5982;&#x4E0B;&#x7684;&#x53C2;&#x6570;&#xFF1A;<br><ul><li>*short*&#xFF1A;&#x8F93;&#x51FA;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x7684;&#x7B2C;&#x4E00;&#x884C;<br></li><li>*full*&#xFF1A;&#x8F93;&#x51FA;&#x5168;&#x90E8;&#x7684;&#x5806;&#x6808;&#x4FE1;&#x606F;</li><li>&#x4EFB;&#x610F;&#x6574;&#x6570;&#xFF1A;&#x8F93;&#x51FA;&#x6307;&#x5B9A;&#x884C;&#x6570;&#x7684;&#x5806;&#x6808;&#x4FE1;&#x606F;</li></ul><br>&#x4E0B;&#x9762;&#x662F;&#x4E00;&#x4E9B;&#x793A;&#x4F8B;&#xFF1A;<br><table><thead><th>&#x8F6C;&#x6362;&#x6A21;&#x5F0F;</th><th>&#x7ED3;&#x679C;</th></thead><tbody><tr><td>%ex</td><td><pre>mainPackage.foo.bar.TestException: Houston we have a problem<br>  at mainPackage.foo.bar.TestThrower.fire(TestThrower.java:22)<br>  at mainPackage.foo.bar.TestThrower.readyToLaunch(TestThrower.java:17)<br>  at mainPackage.ExceptionLauncher.main(ExceptionLauncher.java:38)</pre></td></tr><tr><td>%ex{short}</td><td><pre><br>mainPackage.foo.bar.TestException: Houston we have a problem<br>  at mainPackage.foo.bar.TestThrower.fire(TestThrower.java:22)</pre></td></tr><tr><td>%ex{full}</td><td><pre><br>mainPackage.foo.bar.TestException: Houston we have a problem<br>  at mainPackage.foo.bar.TestThrower.fire(TestThrower.java:22)<br>  at mainPackage.foo.bar.TestThrower.readyToLaunch(TestThrower.java:17)<br>  at mainPackage.ExceptionLauncher.main(ExceptionLauncher.java:38)</pre></td></tr><tr><td>%ex{2}</td><td><pre>mainPackage.foo.bar.TestException: Houston we have a problem<br>  at mainPackage.foo.bar.TestThrower.fire(TestThrower.java:22)<br>  at mainPackage.foo.bar.TestThrower.readyToLaunch(TestThrower.java:17)</pre></td></tr></tbody></table><br>&#x5728;&#x8F93;&#x51FA;&#x524D;&#xFF0C;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x8FD8;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x7ED9;&#x5B9A;&#x7684;&#x6807;&#x51C6;&#x518D;&#x6B21;&#x68C0;&#x9A8C;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x3002;&#x4F8B;&#x5982;&#xFF0C;&#x4F7F;&#x7528; <strong>%ex{full, EX_DISPLAY_EVAL}</strong>&#xFF0C;&#x53EA;&#x6709; <em>EX_DISPLAY_EVAL</em> &#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x5426;&#x5B9A;&#x7684;&#x7B54;&#x6848;&#xFF0C;&#x624D;&#x4F1A;&#x8F93;&#x51FA;&#x5168;&#x90E8;&#x7684;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x3002;evaluator &#x5728;&#x63A5;&#x4E0B;&#x6765;&#x7684;&#x6587;&#x6863;&#x4E2D;&#x5C06;&#x4F1A;&#x8FDB;&#x4E00;&#x6B65;&#x53D9;&#x8FF0;&#x3002;<br>&#x5982;&#x679C;&#x4F60;&#x6CA1;&#x6709;&#x6307;&#x5B9A; %throwable &#x6216;&#x8005;&#x5176;&#x5B83;&#x8DDF; throwable &#x76F8;&#x5173;&#x7684;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#xFF0C;&#x90A3;&#x4E48; <code>PatternLayout</code> &#x4F1A;&#x5728;&#x6700;&#x540E;&#x4E00;&#x4E2A;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x52A0;&#x4E0A;&#x8FD9;&#x4E2A;&#x3002;&#x56E0;&#x4E3A;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x975E;&#x5E38;&#x7684;&#x91CD;&#x8981;&#x3002;&#x5982;&#x679C;&#x4F60;&#x4E0D;&#x60F3;&#x5C55;&#x793A;&#x5806;&#x6808;&#x4FE1;&#x606F;&#xFF0C;&#x90A3;&#x4E48;&#x53EF;&#x4EE5;&#x4F7F;&#x7528; %nopex (&#x4F5C;&#x8005;&#x539F;&#x6587;&#x4E3A; $nopex) &#x53EF;&#x4EE5;&#x66FF;&#x4EE3; %throwable&#x3002;&#x8BE6;&#x60C5;&#x89C1; %nopex&#x3002;</td>
</tr>
<tr>
<td><a style="text-decoration:none" name="xThrowable" href="#xThrowable"><strong>xEx</strong>{<em>depth</em>}</a>  <br><strong>xException</strong>{<em>depth</em>}  <strong>xThrowable</strong>{<em>depth</em>}   <br><strong>xEx</strong>{depth, evaluator-1, ..., evaluator-n}  <br><strong>xException</strong>{depth, evaluator-1, ..., evaluator-n} <br><strong>xThrowable</strong>{depth, evaluator-1, ..., evaluator-n}</td>
<td>&#x8DDF; %throwable &#x7C7B;&#x4F3C;&#xFF0C;&#x53EA;&#x4E0D;&#x8FC7;&#x591A;&#x4E86;&#x7C7B;&#x7684;&#x5305;&#x4FE1;&#x606F;&#x3002;<br>&#x5728;&#x6BCF;&#x4E2A;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x7684;&#x672B;&#x5C3E;&#xFF0C;&#x591A;&#x4E86;&#x5305;&#x542B; jar &#x6587;&#x4EF6;&#x7684;&#x5B57;&#x7B26;&#x4E32;&#xFF0C;&#x540E;&#x9762;&#x518D;&#x52A0;&#x4E0A;&#x5177;&#x4F53;&#x7684;&#x5B9E;&#x73B0;&#x7248;&#x672C;&#x3002;&#x8FD9;&#x9879;&#x521B;&#x9020;&#x6027;&#x7684;&#x6280;&#x672F;&#x662F;&#x6765;&#x81EA; <a href="http://macstrac.blogspot.com/2008/09/better-stack-traces-in-java-with-log4j.html" target="_blank">James Strachan</a> &#x7684;&#x5EFA;&#x8BAE;&#x3002;&#x5982;&#x679C;&#x8BE5;&#x4FE1;&#x606F;&#x4E0D;&#x786E;&#x5B9A;&#xFF0C;&#x90A3;&#x4E48;&#x7C7B;&#x7684;&#x5305;&#x4FE1;&#x606F;&#x524D;&#x9762;&#x4F1A;&#x6709;&#x4E00;&#x4E2A;&#x6CE2;&#x6D6A;&#x53F7; (~)&#x3002;<br>&#x4E0B;&#x9762;&#x662F;&#x4E00;&#x4E2A;&#x4F8B;&#x5B50;&#xFF1A;<br><pre>java.lang.NullPointerException<br>  at com.xyz.Wombat(Wombat.java:57) ~[wombat-1.3.jar:1.3]<br>  at  com.xyz.Wombat(Wombat.java:76) ~[wombat-1.3.jar:1.3]<br>  at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.5.0_06]<br>  at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) ~[na:1.5.0_06]<br>  at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) ~[na:1.5.0_06]<br>  at java.lang.reflect.Method.invoke(Method.java:585) ~[na:1.5.0_06]<br>  at org.junit.internal.runners.TestMethod.invoke(TestMethod.java:59) [junit-4.4.jar:na]<br>  at org.junit.internal.runners.MethodRoadie.runTestMethod(MethodRoadie.java:98) [junit-4.4.jar:na]<br>  ...etc </pre>logback &#x52AA;&#x529B;&#x7684;&#x53BB;&#x786E;&#x4FDD;&#x7C7B;&#x7684;&#x5305;&#x4FE1;&#x606F;&#x6B63;&#x786E;&#x7684;&#x5C55;&#x793A;&#xFF0C;&#x5373;&#x4F7F;&#x662F;&#x5728;&#x590D;&#x6742;&#x7684;&#x7C7B;&#x52A0;&#x8F7D;&#x5C42;&#x6B21;&#x4E2D;&#x3002;&#x4F46;&#x662F;&#xFF0C;&#x4E00;&#x4E2A;&#x4E0D;&#x80FD;&#x4FDD;&#x8BC1;&#x4FE1;&#x606F;&#x7684;&#x7EDD;&#x5BF9;&#x6B63;&#x786E;&#xFF0C;&#x90A3;&#x4E48;&#x5728;&#x8FD9;&#x4E9B;&#x6570;&#x636E;&#x7684;&#x524D;&#x9762;&#x5C06;&#x4F1A;&#x591A;&#x4E00;&#x4E2A;&#x6CE2;&#x6D6A;&#x7B26; (~)&#x3002;&#x56E0;&#x6B64;&#xFF0C;&#x4ECE;&#x7406;&#x8BBA;&#x4E0A;&#x6765;&#x8BF4;&#xFF0C;&#x6253;&#x5370;&#x7684;&#x7C7B;&#x7684;&#x5305;&#x4FE1;&#x606F;&#x8DDF;&#x771F;&#x5B9E;&#x7684;&#x7C7B;&#x7684;&#x5305;&#x4FE1;&#x606F;&#x662F;&#x6709;&#x533A;&#x522B;&#x7684;&#x3002;&#x5728;&#x4E0A;&#x9762;&#x7684;&#x4F8B;&#x5B50;&#x4E2D;&#xFF0C;&#x7C7B; Wombat &#x7684;&#x5305;&#x4FE1;&#x606F;&#x524D;&#x9762;&#x6709;&#x4E00;&#x4E2A;&#x6CE2;&#x6D6A;&#x7B26;&#xFF0C;&#x5728;&#x5B9E;&#x9645;&#x7684;&#x60C5;&#x51B5;&#x4E2D;&#xFF0C;&#x5B83;&#x771F;&#x5B9E;&#x5305;&#x53EF;&#x80FD;&#x4E3A;  [wombat.jar:1.7]&#x3002;<br>&#x4F46;&#x662F;&#x8BF7;&#x6CE8;&#x610F;&#x6F5C;&#x5728;&#x7684;&#x6027;&#x80FD;&#x635F;&#x8017;&#xFF0C;&#x8BA1;&#x7B97;<a href="https://github.com/Volong/logback-chinese-manual/blob/master/03%E7%AC%AC%E4%B8%89%E7%AB%A0%EF%BC%9Alogback%20%E7%9A%84%E9%85%8D%E7%BD%AE.md#%E5%9C%A8%E5%A0%86%E6%A0%88%E4%B8%AD%E5%B1%95%E7%A4%BA%E5%8C%85%E6%95%B0%E6%8D%AE" target="_blank">&#x5305;&#x4FE1;&#x606F;&#x9ED8;&#x8BA4;&#x662F;&#x7981;&#x6B62;&#x7684;</a>&#x3002;&#x5F53;&#x542F;&#x7528;&#x4E86;&#x8BA1;&#x7B97;&#x5305;&#x4FE1;&#x606F;&#xFF0C;&#x90A3;&#x4E48; <code>PatternLayout</code> &#x5C06;&#x4F1A;&#x81EA;&#x52A8;&#x8BA4;&#x4E3A;&#x5728;&#x5B57;&#x7B26;&#x4E32;&#x6A21;&#x5F0F;&#x7684;&#x672B;&#x5C3E; %xThrowable &#x66FF;&#x4EE3;&#x4E86; %throwable&#x3002;<br>&#x6839;&#x636E;&#x7528;&#x6237;&#x7684;<a href="https://jira.qos.ch/browse/LOGBACK-324" target="_blank">&#x53CD;&#x9988;</a>&#xFF0C;Netbeans &#x4F1A;&#x963B;&#x6B62;&#x5305;&#x4FE1;&#x606F;&#x7684;&#x6253;&#x5370;&#x3002;</td>
</tr>
<tr>
<td><strong>nopex</strong><br><strong>nopexception</strong></td>
<td>&#x8FD9;&#x4E2A;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x4E0D;&#x4F1A;&#x8F93;&#x51FA;&#x4EFB;&#x4F55;&#x6570;&#x636E;&#xFF0C;&#x56E0;&#x6B64;&#xFF0C;&#x5B83;&#x53EF;&#x4EE5;&#x7528;&#x6765;&#x6709;&#x6548;&#x5FFD;&#x7565;&#x5F02;&#x5E38;&#x4FE1;&#x606F;&#x3002;<br>%nopex &#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x5141;&#x8BB8;&#x7528;&#x6237;&#x91CD;&#x5199; <code>PatternLayout</code> &#x5185;&#x90E8;&#x7684;&#x5B89;&#x5168;&#x673A;&#x5236;&#xFF0C;&#x8BE5;&#x673A;&#x5236;&#x5C06;&#x4F1A;&#x5728;&#x6CA1;&#x6709;&#x6307;&#x5B9A;&#x5176;&#x5B83;&#x5904;&#x7406;&#x5F02;&#x5E38;&#x7684;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x65F6;&#xFF0C;&#x9ED8;&#x8BA4;&#x6DFB;&#x52A0; %xThrowable&#x3002;</td>
</tr>
<tr>
<td><strong>marker</strong></td>
<td>&#x8F93;&#x51FA;&#x4E0E;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#x76F8;&#x5173;&#x7684;&#x6807;&#x7B7E;&#x3002;<br>&#x4E00;&#x65E6;&#x6807;&#x7B7E;&#x5305;&#x542B;&#x5B50;&#x6807;&#x7B7E;&#xFF0C;&#x90A3;&#x4E48;&#x8F6C;&#x6362;&#x5668;&#x5C06;&#x4F1A;&#x6839;&#x636E;&#x4E0B;&#x9762;&#x7684;&#x683C;&#x5F0F;&#x5C55;&#x793A;&#x7236;&#x6807;&#x7B7E;&#x4E0E;&#x5B50;&#x6807;&#x7B7E;&#x3002;<br><em>parentName [child1, child2]</em></td>
</tr>
<tr>
<td><strong>property{key}</strong></td>
<td>&#x8F93;&#x51FA;&#x5C5E;&#x6027; <em>key</em> &#x6240;&#x5BF9;&#x5E94;&#x7684;&#x503C;&#x3002;&#x76F8;&#x5173;&#x5B9A;&#x4E49;&#x53C2;&#x89C1; <a href="https://github.com/Volong/logback-chinese-manual/blob/master/03%E7%AC%AC%E4%B8%89%E7%AB%A0%EF%BC%9Alogback%20%E7%9A%84%E9%85%8D%E7%BD%AE.md#%E5%8F%98%E9%87%8F%E6%9B%BF%E6%8D%A2" target="_blank">&#x5B9A;&#x4E49;&#x53D8;&#x91CF;</a> &#x4EE5;&#x53CA;<a href="https://github.com/Volong/logback-chinese-manual/blob/master/03%E7%AC%AC%E4%B8%89%E7%AB%A0%EF%BC%9Alogback%20%E7%9A%84%E9%85%8D%E7%BD%AE.md#%E4%BD%9C%E7%94%A8%E5%9F%9F" target="_blank">&#x4F5C;&#x7528;&#x57DF;</a>&#x3002;&#x5982;&#x679C; key &#x5728; logger context &#x4E2D;&#x6CA1;&#x6709;&#x627E;&#x5230;&#xFF0C;&#x90A3;&#x4E48;&#x5C06;&#x4F1A;&#x53BB;&#x7CFB;&#x7EDF;&#x5C5E;&#x6027;&#x4E2D;&#x627E;&#x3002;<br><em>key</em> &#x6CA1;&#x6709;&#x9ED8;&#x8BA4;&#x503C;&#xFF0C;&#x5982;&#x679C;&#x7F3A;&#x5931;&#xFF0C;&#x5219;&#x4F1A;&#x5C55;&#x793A; &quot; Property_HAS_NO_KEY&quot; &#x7684;&#x9519;&#x8BEF;&#x4FE1;&#x606F;&#x3002;</td>
</tr>
<tr>
<td><a style="text-decoration:none" name="replace" href="#replace"><strong>replace(p){r, t}</strong></a></td>
<td>&#x5728;&#x5B50;&#x6A21;&#x5F0F; &apos;p&apos; &#x4EA7;&#x751F;&#x7684;&#x5B57;&#x7B26;&#x4E2D;&#xFF0C;&#x5C06;&#x6240;&#x6709;&#x51FA;&#x73B0;&#x6B63;&#x5219;&#x8868;&#x8FBE;&#x5F0F; &apos;r&apos; &#x7684;&#x5730;&#x65B9;&#x66FF;&#x6362;&#x4E3A; &apos;t&apos;&#x3002;&#x4F8B;&#x5982;&#xFF0C;&quot;%replace(%msg){&apos;\s&apos;, &apos;&apos;}&quot; &#x5C06;&#x4F1A;&#x79FB;&#x9664;&#x4E8B;&#x4EF6;&#x6D88;&#x606F;&#x4E2D;&#x6240;&#x6709;&#x7A7A;&#x683C;&#x3002;<br>&#x6A21;&#x5F0F; &apos;p&apos; &#x53EF;&#x4EE5;&#x662F;&#x4EFB;&#x610F;&#x590D;&#x6742;&#x7684;&#x751A;&#x81F3;&#x7531;&#x591A;&#x4E2A;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x7EC4;&#x6210;&#x3002;&#x4F8B;&#x5982;&#xFF0C;&quot;%replace(%logger %msg){&apos;.&apos;, &apos;/&apos;}&quot; &#x5C06;&#x4F1A;&#x66FF;&#x6362; logger &#x4EE5;&#x53CA;&#x6D88;&#x606F;&#x4E2D;&#x6240;&#x6709;&#x7684;&#x70B9;&#x4E3A;&#x659C;&#x6746;&#x3002;</td>
</tr>
<tr>
<td><strong>rEx</strong>{<em>depth</em>}  <strong>rootException</strong>{<em>depth</em>}   <strong>rEx</strong>{depth, evaluator-1, ..., evaluator-n}  <strong>rootException</strong>{depth, evaluator-1, ..., evaluator-n}</td>
<td>&#x8F93;&#x51FA;&#x4E0E;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x76F8;&#x5173;&#x7684;&#x5806;&#x6808;&#x4FE1;&#x606F;&#xFF0C;&#x6839;&#x5F02;&#x5E38;&#x5C06;&#x4F1A;&#x9996;&#x5148;&#x8F93;&#x51FA;&#xFF0C;&#x800C;&#x662F;&#x6807;&#x51C6;&#x7684;&quot;&#x6839;&#x5F02;&#x5E38;&#x6700;&#x540E;&#x8F93;&#x51FA;&quot;&#x3002;&#x4E0B;&#x9762;&#x662F;&#x4E00;&#x4E2A;&#x8F93;&#x51FA;&#x4F8B;&#x5B50;&#xFF1A;<br><pre>java.lang.NullPointerException<br>  at com.xyz.Wombat(Wombat.java:57) ~[wombat-1.3.jar:1.3]<br>  at com.xyz.Wombat(Wombat.java:76) ~[wombat-1.3.jar:1.3]<br>Wrapped by: org.springframework.BeanCreationException: Error creating bean with name &apos;wombat&apos;: <br>  at org.springframework.AbstractBeanFactory.getBean(AbstractBeanFactory.java:248) [spring-2.0.jar:2.0]<br>  at org.springframework.AbstractBeanFactory.getBean(AbstractBeanFactory.java:170) [spring-2.0.jar:2.0]<br>  at org.apache.catalina.StandardContext.listenerStart(StandardContext.java:3934) [tomcat-6.0.26.jar:6.0.26]</pre>%rootException &#x8DDF; %xException &#x7C7B;&#x4F3C;&#xFF0C;&#x4E5F;&#x5141;&#x8BB8;&#x4E00;&#x4E9B;&#x53EF;&#x9009;&#x7684;&#x53C2;&#x6570;&#xFF0C;&#x5305;&#x62EC;&#x6DF1;&#x5EA6;&#x4EE5;&#x53CA; evaluator&#x3002;&#x5B83;&#x4E5F;&#x4F1A;&#x8F93;&#x51FA;&#x5305;&#x4FE1;&#x606F;&#x3002;&#x7B80;&#x5355;&#x6765;&#x8BF4;&#xFF0C;%rootException &#x8DDF; %xException &#x975E;&#x5E38;&#x7684;&#x7C7B;&#x4F3C;&#xFF0C;&#x4EC5;&#x4EC5;&#x662F;&#x5F02;&#x5E38;&#x8F93;&#x51FA;&#x7684;&#x987A;&#x5E8F;&#x5B8C;&#x5168;&#x76F8;&#x53CD;&#x3002;<br>  %rootException &#x7684;&#x4F5C;&#x8005; Tomasz Nurkiewicz &#x5728;&#x4ED6;&#x7684;&#x535A;&#x5BA2;&#x8BF4;&#x660E;&#x4E86;&#x4ED6;&#x6240;&#x4F5C;&#x7684;&#x8D21;&#x732E; <a href="http://nurkiewicz.blogspot.com/2011/09/logging-exceptions-root-cause-first.html" target="_blank">&quot;Logging exceptions root cause first&quot;</a>&#x3002;</td>
</tr>
</tbody>
</table>
<h4 id="&#x6709;&#x7279;&#x6B8A;&#x7684;&#x542B;&#x4E49;">% &#x6709;&#x7279;&#x6B8A;&#x7684;&#x542B;&#x4E49;</h4>
<p>&#x5728;&#x7ED9;&#x5B9A;&#x7684;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x4E0A;&#x4E0B;&#x6587;&#x4E2D;&#xFF0C;% &#x6709;&#x7279;&#x6B8A;&#x7684;&#x542B;&#x4E49;&#x3002;&#x5982;&#x679C;&#x4F5C;&#x4E3A;&#x5B57;&#x9762;&#x91CF;&#xFF0C;&#x9700;&#x8981;&#x8FDB;&#x884C;&#x8F6C;&#x4E49;&#x3002;&#x4F8B;&#x5982;&#xFF0C;&quot;%d %p \% %m%n&quot;&#x3002;</p>
<h4 id="&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x5BF9;&#x5B57;&#x9762;&#x91CF;&#x7684;&#x9650;&#x5236;">&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x5BF9;&#x5B57;&#x9762;&#x91CF;&#x7684;&#x9650;&#x5236;</h4>
<p>&#x5728;&#x5927;&#x591A;&#x6570;&#x7684;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x5B57;&#x9762;&#x91CF;&#x5305;&#x62EC;&#x7A7A;&#x683C;&#x6216;&#x8005;&#x5176;&#x5B83;&#x7684;&#x5206;&#x9694;&#x7B26;&#xFF0C;&#x6240;&#x4EE5;&#x5B83;&#x4EEC;&#x4E0D;&#x4F1A;&#x4E0E;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x6DF7;&#x6DC6;&#x3002;&#x4F8B;&#x5982;&#xFF0C;&quot;%level [%thread] - %message%n&quot; &#x5305;&#x542B;&#x5B57;&#x9762;&#x91CF;&#x5B57;&#x7B26; &quot; [&quot; &#x4E0E; &quot;] - &quot;&#x3002;&#x4F46;&#x662F;&#xFF0C;&#x5982;&#x679C;&#x4E00;&#x4E2A;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x540E;&#x9762;&#x7D27;&#x8DDF;&#x7740;&#x4E00;&#x4E2A;&#x5B57;&#x9762;&#x91CF;&#xFF0C;&#x90A3;&#x4E48; logback &#x7684;&#x6A21;&#x5F0F;&#x89E3;&#x6790;&#x5668;&#x5C06;&#x4F1A;&#x9519;&#x8BEF;&#x7684;&#x8BA4;&#x4E3A;&#x8FD9;&#x4E2A;&#x5B57;&#x9762;&#x91CF;&#x4E5F;&#x662F;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x7684;&#x4E00;&#x90E8;&#x5206;&#x3002;&#x4F8B;&#x5982;&#xFF0C;&quot;%date<strong>%nHello</strong>&quot; &#x5C06;&#x4F1A;&#x88AB;&#x89E3;&#x6790;&#x6210;&#x4E24;&#x4E2A;&#x8F6C;&#x6362;&#x5B57;&#x7B26; %date &#x4E0E; %nHello&#xFF0C;&#x4F46;&#x662F; %nHello &#x4E0D;&#x662F;&#x4E00;&#x4E2A;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#xFF0C;&#x6240;&#x4EE5; logback &#x5C06;&#x4F1A;&#x8F93;&#x51FA; %PARSER_ERROR[nHello]&#x3002;&#x5982;&#x679C;&#x4F60;&#x60F3;&#x8981;&#x533A;&#x5206; %n &#x8DDF; Hello&#xFF0C;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x7ED9; %n &#x4F20;&#x9012;&#x4E00;&#x4E2A;&#x7A7A;&#x53C2;&#x6570;&#x3002;&#x4F8B;&#x5982;&#xFF0C;&quot;%date<strong>%n{}</strong>Hello&quot; &#x5C06;&#x4F1A;&#x88AB;&#x89E3;&#x6790;&#x4E3A; %date %n &#x518D;&#x7D27;&#x8DDF;&#x7740;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;&#x4E32; &quot;Hello&quot;&#x3002;</p>
<h2 id="&#x683C;&#x5F0F;&#x4FEE;&#x6539;&#x5668;">&#x683C;&#x5F0F;&#x4FEE;&#x6539;&#x5668;</h2>
<p>&#x9ED8;&#x8BA4;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x76F8;&#x5173;&#x4FE1;&#x606F;&#x6309;&#x7167;&#x539F;&#x6837;&#x8F93;&#x51FA;&#x3002;&#x4F46;&#x662F;&#xFF0C;&#x5728;&#x683C;&#x5F0F;&#x4FEE;&#x6539;&#x5668;&#x7684;&#x5E2E;&#x52A9;&#x4E0B;&#xFF0C;&#x53EF;&#x4EE5;&#x5BF9;&#x6BCF;&#x4E2A;&#x6570;&#x636E;&#x5B57;&#x6BB5;&#x8FDB;&#x884C;&#x5BF9;&#x9F50;&#xFF0C;&#x4EE5;&#x53CA;&#x66F4;&#x6539;&#x6700;&#x5927;&#x6700;&#x5C0F;&#x5BBD;&#x5EA6;&#x3002;</p>
<p>&#x53EF;&#x9009;&#x7684;&#x683C;&#x5F0F;&#x4FEE;&#x6539;&#x5668;&#x653E;&#x5728;&#x767E;&#x5206;&#x53F7;&#x8DDF;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x4E4B;&#x95F4;&#x3002;</p>
<p>&#x7B2C;&#x4E00;&#x4E2A;&#x53EF;&#x9009;&#x7684;&#x683C;&#x5F0F;&#x4FEE;&#x6539;&#x5668;&#x662F;<em>&#x5DE6;&#x5BF9;&#x9F50;&#x6807;&#x5FD7;</em>&#xFF0C;&#x4E5F;&#x5C31;&#x662F;&#x51CF;&#x53F7; (-) &#x5B57;&#x7B26;&#x3002;&#x63A5;&#x4E0B;&#x6765;&#x7684;&#x662F;<em>&#x6700;&#x5C0F;&#x5B57;&#x6BB5;&#x5BBD;&#x5EA6;&#x4FEE;&#x6539;&#x5668;</em>&#xFF0C;&#x5B83;&#x662F;&#x4E00;&#x4E2A;&#x5341;&#x8FDB;&#x5236;&#x5E38;&#x91CF;&#xFF0C;&#x8868;&#x793A;&#x8F93;&#x51FA;&#x81F3;&#x5C11;&#x591A;&#x5C11;&#x4E2A;&#x5B57;&#x7B26;&#x3002;&#x5982;&#x679C;&#x5B57;&#x6BB5;&#x5305;&#x542B;&#x5F88;&#x5C11;&#x7684;&#x6570;&#x636E;&#xFF0C;&#x5B83;&#x4F1A;&#x9009;&#x62E9;&#x586B;&#x5145;&#x5DE6;&#x8FB9;&#x6216;&#x8005;&#x53F3;&#x8FB9;&#xFF0C;&#x76F4;&#x5230;&#x6EE1;&#x8DB3;&#x6700;&#x5C0F;&#x5BBD;&#x5EA6;&#x3002;&#x9ED8;&#x8BA4;&#x662F;&#x586B;&#x5145;&#x5DE6;&#x8FB9; (&#x53F3;&#x5BF9;&#x9F50;)&#xFF0C;&#x4F46;&#x662F;&#x4F60;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x5DE6;&#x5BF9;&#x9F50;&#x6807;&#x5FD7;&#x6765;&#x5BF9;&#x53F3;&#x8FB9;&#x8FDB;&#x884C;&#x586B;&#x5145;&#x3002;&#x586B;&#x5145;&#x5B57;&#x7B26;&#x4E3A;&#x7A7A;&#x683C;&#x3002;&#x5982;&#x679C;&#x5B57;&#x6BB5;&#x7684;&#x6570;&#x636E;&#x5927;&#x4E8E;&#x6700;&#x5C0F;&#x5B57;&#x6BB5;&#x7684;&#x5BBD;&#x5EA6;&#xFF0C;&#x4F1A;&#x81EA;&#x52A8;&#x6269;&#x5BB9;&#x53BB;&#x5BB9;&#x7EB3;&#x6240;&#x6709;&#x7684;&#x6570;&#x636E;&#x3002;&#x5B57;&#x6BB5;&#x7684;&#x6570;&#x636E;&#x6C38;&#x8FDC;&#x4E0D;&#x4F1A;&#x88AB;&#x622A;&#x65AD;&#x3002;</p>
<p>&#x8FD9;&#x4E2A;&#x884C;&#x4E3A;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x4F7F;&#x7528;<em>&#x6700;&#x5927;&#x5B57;&#x6BB5;&#x5BBD;&#x5EA6;&#x4FEE;&#x6539;&#x5668;</em>&#x6765;&#x6539;&#x53D8;&#xFF0C;&#x5B83;&#x901A;&#x8FC7;&#x4E00;&#x4E2A;&#x70B9;&#x540E;&#x9762;&#x8DDF;&#x7740;&#x4E00;&#x4E2A;&#x5341;&#x8FDB;&#x5236;&#x5E38;&#x91CF;&#x6765;&#x6307;&#x5B9A;&#x3002;&#x5982;&#x679C;&#x5B57;&#x6BB5;&#x7684;&#x6570;&#x636E;&#x957F;&#x5EA6;&#x5927;&#x4E8E;&#x6700;&#x5927;&#x5B57;&#x6BB5;&#x7684;&#x5BBD;&#x5EA6;&#xFF0C;&#x90A3;&#x4E48;&#x4F1A;&#x4ECE;&#x6570;&#x636E;&#x5B57;&#x6BB5;&#x7684;&#x5F00;&#x5934;&#x79FB;&#x9664;&#x591A;&#x4F59;&#x7684;&#x5B57;&#x7B26;&#x3002;&#x4E3E;&#x4E2A;&#x1F330;&#xFF0C;&#x5982;&#x679C;&#x6700;&#x5927;&#x5B57;&#x6BB5;&#x7684;&#x5BBD;&#x5EA6;&#x662F; 8&#xFF0C;&#x6570;&#x636E;&#x957F;&#x5EA6;&#x662F;&#x5341;&#x4E2A;&#x5B57;&#x7B26;&#x7684;&#x957F;&#x5EA6;&#xFF0C;&#x90A3;&#x4E48;&#x5F00;&#x5934;&#x7684;&#x4E24;&#x4E2A;&#x5B57;&#x7B26;&#x5C06;&#x4F1A;&#x88AB;&#x4E22;&#x5F03;&#x3002;&#x8FD9;&#x4E2A;&#x884C;&#x4E3A;&#x8DDF; C &#x8BED;&#x8A00;&#x4E2D; printf &#x51FD;&#x6570;&#x4ECE;&#x540E;&#x9762;&#x5F00;&#x59CB;&#x622A;&#x65AD;&#x7684;&#x884C;&#x4E3A;&#x76F8;&#x8FDD;&#x80CC;&#x3002;</p>
<p>&#x5982;&#x679C;&#x60F3;&#x4ECE;&#x540E;&#x9762;&#x5F00;&#x59CB;&#x622A;&#x65AD;&#xFF0C;&#x53EF;&#x4EE5;&#x5728;&#x70B9;&#x540E;&#x9762;&#x589E;&#x52A0;&#x4E00;&#x4E2A;&#x51CF;&#x53F7;&#x3002;&#x5982;&#x679C;&#x662F;&#x8FD9;&#x6837;&#x7684;&#x8BDD;&#xFF0C;&#x6700;&#x5927;&#x5B57;&#x6BB5;&#x5BBD;&#x5EA6;&#x662F; 8&#xFF0C;&#x6570;&#x636E;&#x957F;&#x5EA6;&#x662F;&#x5341;&#x4E2A;&#x5B57;&#x7B26;&#x7684;&#x957F;&#x5EA6;&#xFF0C;&#x90A3;&#x4E48;&#x6700;&#x540E;&#x4E24;&#x4E2A;&#x5B57;&#x7B26;&#x5C06;&#x4F1A;&#x88AB;&#x4E22;&#x5F03;&#x3002;</p>
<p>&#x4E0B;&#x9762;&#x662F;&#x5404;&#x79CD;&#x683C;&#x5F0F;&#x4FEE;&#x6539;&#x5668;&#x7684;&#x4F8B;&#x5B50;&#xFF1A;</p>
<table>
<thead>
<tr>
<th>&#x683C;&#x5F0F;&#x4FEE;&#x6539;&#x5668;</th>
<th>&#x5DE6;&#x5BF9;&#x9F50;</th>
<th>&#x6700;&#x5C0F;&#x5BBD;&#x5EA6;</th>
<th>&#x6700;&#x5927;&#x5BBD;&#x5EA6;</th>
<th>&#x5907;&#x6CE8;</th>
</tr>
</thead>
<tbody>
<tr>
<td>%20logger</td>
<td>false</td>
<td>20</td>
<td>none</td>
<td>&#x5982;&#x679C; logger &#x7684;&#x540D;&#x5B57;&#x5C0F;&#x4E8E; 20 &#x4E2A;&#x5B57;&#x7B26;&#x7684;&#x957F;&#x5EA6;&#xFF0C;&#x90A3;&#x4E48;&#x4F1A;&#x5728;&#x5DE6;&#x8FB9;&#x586B;&#x5145;&#x7A7A;&#x683C;</td>
</tr>
<tr>
<td>%-20logger</td>
<td>true</td>
<td>20</td>
<td>none</td>
<td>&#x5982;&#x679C; logger &#x7684;&#x540D;&#x5B57;&#x5C0F;&#x4E8E; 20 &#x4E2A;&#x5B57;&#x7B26;&#x7684;&#x957F;&#x5EA6;&#xFF0C;&#x90A3;&#x4E48;&#x4F1A;&#x5728;&#x53F3;&#x8FB9;&#x586B;&#x5145;&#x7A7A;&#x683C;</td>
</tr>
<tr>
<td>%.30logger</td>
<td>NA</td>
<td>none</td>
<td>30</td>
<td>&#x5982;&#x679C; logger &#x7684;&#x540D;&#x5B57;&#x5927;&#x4E8E; 30 &#x4E2A;&#x5B57;&#x7B26;&#x7684;&#x957F;&#x5EA6;&#xFF0C;&#x90A3;&#x4E48;&#x4ECE;&#x524D;&#x9762;&#x5F00;&#x59CB;&#x622A;&#x65AD;</td>
</tr>
<tr>
<td>%20.30logger</td>
<td>false</td>
<td>20</td>
<td>30</td>
<td>&#x5982;&#x679C; logger &#x7684;&#x540D;&#x5B57;&#x5927;&#x4E8E; 20 &#x4E2A;&#x5B57;&#x7B26;&#x7684;&#x957F;&#x5EA6;&#xFF0C;&#x90A3;&#x4E48;&#x4F1A;&#x4ECE;&#x5DE6;&#x8FB9;&#x586B;&#x5145;&#x7A7A;&#x683C;&#x3002;&#x4F46;&#x662F;&#x5982;&#x679C; logger &#x7684;&#x540D;&#x5B57;&#x5927;&#x4E8E; 30 &#x5B57;&#x7B26;&#xFF0C;&#x5C06;&#x4F1A;&#x4ECE;&#x524D;&#x9762;&#x5F00;&#x59CB;&#x622A;&#x65AD;</td>
</tr>
<tr>
<td>%-20.30logger</td>
<td>true</td>
<td>20</td>
<td>30</td>
<td>&#x5982;&#x679C; logger &#x7684;&#x540D;&#x5B57;&#x5C0F;&#x4E8E; 20 &#x4E2A;&#x5B57;&#x7B26;&#x7684;&#x957F;&#x5EA6;&#xFF0C;&#x90A3;&#x4E48;&#x4ECE;&#x53F3;&#x8FB9;&#x5F00;&#x59CB;&#x586B;&#x5145;&#x7A7A;&#x683C;&#x3002;&#x4F46;&#x662F;&#x5982;&#x679C; logger &#x7684;&#x540D;&#x5B57;&#x5927;&#x4E8E; 30 &#x4E2A;&#x5B57;&#x7B26;&#xFF0C;&#x5C06;&#x4F1A;&#x4ECE;&#x524D;&#x9762;&#x5F00;&#x59CB;&#x622A;&#x65AD;</td>
</tr>
<tr>
<td>%.-30logger</td>
<td>NA</td>
<td>none</td>
<td>30</td>
<td>&#x5982;&#x679C; logger &#x7684;&#x540D;&#x5B57;&#x5927;&#x4E8E; 30 &#x4E2A;&#x5B57;&#x7B26;&#x7684;&#x957F;&#x5EA6;&#xFF0C;&#x90A3;&#x4E48;&#x4ECE;&#x540E;&#x9762;&#x5F00;&#x59CB;&#x622A;&#x65AD;</td>
</tr>
</tbody>
</table>
<p>&#x4E0B;&#x9762;&#x7684;&#x8868;&#x683C;&#x5217;&#x51FA;&#x4E86;&#x683C;&#x5F0F;&#x4FEE;&#x6539;&#x5668;&#x622A;&#x65AD;&#x7684;&#x4F8B;&#x5B50;&#x3002;&#x4F46;&#x662F;&#x8BF7;&#x6CE8;&#x610F;&#x7EFC;&#x62EC;&#x53F7; &quot;[]&quot; &#x4E0D;&#x662F;&#x8F93;&#x51FA;&#x7ED3;&#x679C;&#x7684;&#x4E00;&#x90E8;&#x5206;&#xFF0C;&#x5B83;&#x53EA;&#x662F;&#x7528;&#x6765;&#x533A;&#x5206;&#x8F93;&#x51FA;&#x7684;&#x957F;&#x5EA6;&#x3002;</p>
<table>
<thead>
<tr>
<th>&#x683C;&#x5F0F;&#x4FEE;&#x6539;&#x5668;</th>
<th>logger &#x7684;&#x540D;&#x5B57;</th>
<th>&#x7ED3;&#x679C;</th>
</tr>
</thead>
<tbody>
<tr>
<td>[%20.20logger]</td>
<td>main.Name</td>
<td>[&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;main.Name]</td>
</tr>
<tr>
<td>[%-20.20logger]</td>
<td>main.Name</td>
<td>[main.Name&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;&#xA0;]</td>
</tr>
<tr>
<td>[%10.10logger]</td>
<td>main.foo.foo.bar.Name</td>
<td>[o.bar.Name]</td>
</tr>
<tr>
<td>[%10.-10logger]</td>
<td>main.foo.foo.bar.Name</td>
<td>[main.foo.f]</td>
</tr>
</tbody>
</table>
<h3 id="&#x53EA;&#x8F93;&#x51FA;&#x65E5;&#x5FD7;&#x7B49;&#x7EA7;&#x7684;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;">&#x53EA;&#x8F93;&#x51FA;&#x65E5;&#x5FD7;&#x7B49;&#x7EA7;&#x7684;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;</h3>
<p>&#x9664;&#x4E86;&#x53EF;&#x4EE5;&#x8F93;&#x51FA; TRACE, DEBUG, WARN, INFO &#x6216;&#x8005; ERROR &#x6765;&#x8868;&#x793A;&#x65E5;&#x5FD7;&#x7B49;&#x7EA7;&#x4E4B;&#x5916;&#xFF0C;&#x8FD8;&#x662F;&#x8F93;&#x51FA;T, D, W, I &#x4E0E; E &#x6765;&#x8FDB;&#x884C;&#x8868;&#x793A;&#x3002;&#x4F60;&#x53EF;&#x4EE5;<a href="https://logback.qos.ch/manual/layouts.html#customConversionSpecifier" target="_blank">&#x81EA;&#x5B9A;&#x4E49;&#x8F6C;&#x6362;&#x5668;</a> &#x6216;&#x8005;&#x5229;&#x7528;&#x521A;&#x624D;&#x8BA8;&#x8BBA;&#x7684;&#x683C;&#x5F0F;&#x4FEE;&#x6539;&#x5668;&#x6765;&#x7F29;&#x77ED;&#x65E5;&#x5FD7;&#x7EA7;&#x522B;&#x4E3A;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;&#x3002;&#x8FD9;&#x4E2A;&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;&#x53EF;&#x80FD;&#x4E3A; &quot;%.-1level&quot;&#x3002;</p>
<h2 id="&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x7684;&#x9009;&#x9879;">&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x7684;&#x9009;&#x9879;</h2>
<p>&#x4E00;&#x4E2A;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x540E;&#x9762;&#x53EF;&#x4EE5;&#x8DDF;&#x4E00;&#x4E2A;&#x9009;&#x9879;&#x3002;&#x5B83;&#x4EEC;&#x901A;&#x8FC7;&#x7EFC;&#x62EC;&#x53F7;&#x6765;&#x58F0;&#x660E;&#x3002;&#x6211;&#x4EEC;&#x4E4B;&#x524D;&#x5DF2;&#x7ECF;&#x770B;&#x5230;&#x4E86;&#x4E00;&#x4E9B;&#x53EF;&#x80FD;&#x7684;&#x9009;&#x9879;&#x3002;&#x4F8B;&#x5982;&#x4E4B;&#x524D;&#x7684; MDC &#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26; <em>%mdc{someKey}</em>&#x3002;</p>
<p>&#x4E00;&#x4E2A;&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;&#x53EF;&#x80FD;&#x6709;&#x591A;&#x4E2A;&#x53EF;&#x9009;&#x9879;&#x3002;&#x4E00;&#x4E2A;&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;&#x53EF;&#x4EE5;&#x5145;&#x5206;&#x5229;&#x7528;&#x6211;&#x4EEC;&#x5373;&#x5C06;&#x4ECB;&#x7ECD;&#x5230;&#x7684; evaluator&#xFF0C;&#x53EF;&#x4EE5;&#x6DFB;&#x52A0;&#x591A;&#x4E2A; evaluator &#x7684;&#x540D;&#x5B57;&#x5230;&#x53EF;&#x9009;&#x5217;&#x8868;&#x3002;&#x5982;&#x4E0B;&#xFF1A;</p>
<pre><code class="lang-xml"><span class="hljs-tag">&lt;<span class="hljs-name">pattern</span>&gt;</span>%-4relative [%thread] %-5level - %msg%n \
  %caller{2, DISP_CALLER_EVAL, OTHER_EVAL_NAME, THIRD_EVAL_NAME}<span class="hljs-tag">&lt;/<span class="hljs-name">pattern</span>&gt;</span>
</code></pre>
<p>&#x5982;&#x679C;&#x8FD9;&#x4E9B;&#x9009;&#x9879;&#x4E2D;&#x5305;&#x542B;&#x4E86;&#x4E00;&#x4E9B;&#x7279;&#x6B8A;&#x5B57;&#x7B26;&#xFF0C;&#x4F8B;&#x5982;&#x82B1;&#x62EC;&#x53F7;&#xFF0C;&#x7A7A;&#x683C;&#xFF0C;&#x9017;&#x53F7;&#x3002;&#x4F60;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x5355;&#x5F15;&#x53F7;&#x6216;&#x8005;&#x53CC;&#x5F15;&#x53F7;&#x6765;&#x5305;&#x88F9;&#x5B83;&#x4EEC;&#x3002;&#x4F8B;&#x5982;&#xFF1A;</p>
<pre><code class="lang-xml"><span class="hljs-tag">&lt;<span class="hljs-name">pattern</span>&gt;</span>%-5level - %replace(%msg){&apos;\d{14,16}&apos;, &apos;XXXX&apos;}%n<span class="hljs-tag">&lt;/<span class="hljs-name">pattern</span>&gt;</span>
</code></pre>
<p>&#x6211;&#x4EEC;&#x4F20;&#x9012; <code>\d{16}</code> &#x4E0E; <code>XXXX</code>  &#x7ED9; <code>replace</code> &#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x3002;&#x5B83;&#x5C06;&#x6D88;&#x606F;&#x4E2D; 14&#xFF0C;15 &#x6216;&#x8005; 16 &#x4F4D;&#x7684;&#x6570;&#x5B57;&#x66FF;&#x6362;&#x4E3A; XXXX&#xFF0C;&#x7528;&#x6765;&#x6DF7;&#x6DC6;&#x4FE1;&#x7528;&#x5361;&#x53F7;&#x7801;&#x3002;&#x5728;&#x6B63;&#x5219;&#x8868;&#x8FBE;&#x5F0F;&#x4E2D;&#xFF0C;&quot;\d&quot; &#x8868;&#x793A;&#x4E00;&#x4E2A;&#x6570;&#x5B57;&#x7684;&#x7B80;&#x5199;&#x3002;&quot;{14,16}&quot; &#x4F1A;&#x88AB;&#x89E3;&#x6790;&#x6210; &quot;{14,16}&quot;&#xFF0C;&#x4E5F;&#x5C31;&#x662F;&#x8BF4;&#x524D;&#x4E00;&#x4E2A;&#x9879;&#x5C06;&#x4F1A;&#x88AB;&#x91CD;&#x590D;&#x81F3;&#x5C11; 14 &#x6B21;&#xFF0C;&#x81F3;&#x591A; 16 &#x6B21;&#x3002;</p>
<h2 id="&#x7279;&#x6B8A;&#x7684;&#x5706;&#x62EC;&#x53F7;">&#x7279;&#x6B8A;&#x7684;&#x5706;&#x62EC;&#x53F7;</h2>
<p>&#x5728; logback &#x91CC;&#xFF0C;&#x6A21;&#x5F0F;&#x5B57;&#x7B26;&#x4E32;&#x4E2D;&#x7684;&#x5706;&#x62EC;&#x53F7;&#x88AB;&#x770B;&#x4F5C;&#x4E3A;&#x5206;&#x7EC4;&#x6807;&#x8BB0;&#x3002;&#x56E0;&#x6B64;&#xFF0C;&#x5B83;&#x80FD;&#x591F;&#x5BF9;&#x5B50;&#x6A21;&#x5F0F;&#x8FDB;&#x884C;&#x5206;&#x7EC4;&#xFF0C;&#x5E76;&#x4E14;&#x76F4;&#x63A5;&#x5BF9;&#x5B50;&#x6A21;&#x5F0F;&#x8FDB;&#x884C;&#x683C;&#x5F0F;&#x5316;&#x3002;&#x5728; 0.9.27 &#x7248;&#x672C;&#xFF0C;logback &#x5F00;&#x59CB;&#x652F;&#x6301;&#x7EFC;&#x5408;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#xFF0C;&#x4F8B;&#x5982; <a href="https://github.com/Volong/logback-chinese-manual/blob/master/06%E7%AC%AC%E5%85%AD%E7%AB%A0%EF%BC%9ALayout.md#replace" target="_blank">%replace</a> &#x53EF;&#x4EE5;&#x5BF9;&#x5B50;&#x6A21;&#x5F0F;&#x8FDB;&#x884C;&#x8F6C;&#x6362;&#x3002;</p>
<p>&#x4F8B;&#x5982;&#x4E00;&#x4E0B;&#x6A21;&#x5F0F;&#xFF1A;</p>
<pre><code>%-30(%d{HH:mm:ss.SSS} [%thread]) %-5level %logger{32} - %msg%n
</code></pre><p>&#x5C06;&#x4F1A;&#x5BF9;&#x5B50;&#x6A21;&#x5F0F; &quot;%d{HH:mm:ss.SSS} [%thread]&quot; &#x8FDB;&#x884C;&#x5206;&#x7EC4;&#x8F93;&#x51FA;&#xFF0C;&#x4E3A;&#x4E86;&#x5728;&#x5C11;&#x4E8E; 30 &#x4E2A;&#x5B57;&#x7B26;&#x65F6;&#x8FDB;&#x884C;&#x53F3;&#x586B;&#x5145;&#x3002;</p>
<p>&#x5982;&#x679C;&#x6CA1;&#x6709;&#x8FDB;&#x884C;&#x5206;&#x7EC4;&#x5C06;&#x4F1A;&#x8F93;&#x51FA;&#xFF1A;</p>
<pre><code class="lang-java"><span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">30</span> [main] DEBUG c.q.logback.demo.ContextListener - Classload hashcode is <span class="hljs-number">13995234</span>
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">30</span> [main] DEBUG c.q.logback.demo.ContextListener - Initializing <span class="hljs-keyword">for</span> ServletContext
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">30</span> [main] DEBUG c.q.logback.demo.ContextListener - Trying platform Mbean server
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">30</span> [pool-<span class="hljs-number">1</span>-thread-<span class="hljs-number">1</span>] INFO  ch.qos.logback.demo.LoggingTask - Howdydy-diddly-ho - <span class="hljs-number">0</span>
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">38</span> [btpool0-<span class="hljs-number">7</span>] INFO c.q.l.demo.lottery.LotteryAction - Number: <span class="hljs-number">50</span> was tried.
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">40</span> [btpool0-<span class="hljs-number">7</span>] INFO c.q.l.d.prime.NumberCruncherImpl - Beginning to factor.
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">40</span> [btpool0-<span class="hljs-number">7</span>] DEBUG c.q.l.d.prime.NumberCruncherImpl - Trying <span class="hljs-number">2</span> as a factor.
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">40</span> [btpool0-<span class="hljs-number">7</span>] INFO c.q.l.d.prime.NumberCruncherImpl - Found factor <span class="hljs-number">2</span>
</code></pre>
<p>&#x5982;&#x679C;&#x5BF9; &quot;%-30()&quot; &#x8FDB;&#x884C;&#x5206;&#x7EC4;&#x5C06;&#x4F1A;&#x8F93;&#x51FA;&#xFF1A;</p>
<pre><code class="lang-java"><span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">30</span> [main]            DEBUG c.q.logback.demo.ContextListener - Classload hashcode is <span class="hljs-number">13995234</span>
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">30</span> [main]            DEBUG c.q.logback.demo.ContextListener - Initializing <span class="hljs-keyword">for</span> ServletContext
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">30</span> [main]            DEBUG c.q.logback.demo.ContextListener - Trying platform Mbean server
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">30</span> [pool-<span class="hljs-number">1</span>-thread-<span class="hljs-number">1</span>] INFO  ch.qos.logback.demo.LoggingTask - Howdydy-diddly-ho - <span class="hljs-number">0</span>
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">38</span> [btpool0-<span class="hljs-number">7</span>]       INFO  c.q.l.demo.lottery.LotteryAction - Number: <span class="hljs-number">50</span> was tried.
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">40</span> [btpool0-<span class="hljs-number">7</span>]       INFO  c.q.l.d.prime.NumberCruncherImpl - Beginning to factor.
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">40</span> [btpool0-<span class="hljs-number">7</span>]       DEBUG c.q.l.d.prime.NumberCruncherImpl - Trying <span class="hljs-number">2</span> as a factor.
<span class="hljs-number">13</span>:<span class="hljs-number">09</span>:<span class="hljs-number">40</span> [btpool0-<span class="hljs-number">7</span>]       INFO  c.q.l.d.prime.NumberCruncherImpl - Found factor <span class="hljs-number">2</span>
</code></pre>
<p>&#x540E;&#x8005;&#x7684;&#x683C;&#x5F0F;&#x66F4;&#x52A0;&#x5BB9;&#x6613;&#x9605;&#x8BFB;&#x3002;</p>
<p>&#x5982;&#x679C;&#x4F60;&#x60F3;&#x5C06;&#x5706;&#x62EC;&#x53F7;&#x5F53;&#x4F5C;&#x5B57;&#x9762;&#x91CF;&#x8F93;&#x51FA;&#xFF0C;&#x90A3;&#x4E48;&#x4F60;&#x9700;&#x8981;&#x5BF9;&#x6BCF;&#x4E2A;&#x5706;&#x62EC;&#x53F7;&#x7528;&#x53CD;&#x659C;&#x6760;&#x8FDB;&#x884C;&#x8F6C;&#x4E49;&#x3002;&#x5C31;&#x50CF; <strong>(</strong>%d{HH:mm:ss.SSS} [%thread]<strong>)</strong> &#x4E00;&#x6837;&#x3002;</p>
<h2 id="&#x7740;&#x8272;">&#x7740;&#x8272;</h2>
<p>&#x5982;&#x4E0A;&#x6240;&#x8FF0;&#x7684;<a href="https://github.com/Volong/logback-chinese-manual/blob/master/06%E7%AC%AC%E5%85%AD%E7%AB%A0%EF%BC%9ALayout.md#%E7%89%B9%E6%AE%8A%E7%9A%84%E5%9C%86%E6%8B%AC%E5%8F%B7" target="_blank">&#x5706;&#x62EC;&#x53F7;</a>&#x5206;&#x7EC4;&#xFF0C;&#x5141;&#x8BB8;&#x5BF9;&#x5B50;&#x6A21;&#x5F0F;&#x8FDB;&#x884C;&#x7740;&#x8272;&#x3002;&#x5728; 1.0.5 &#x7248;&#x672C;&#xFF0C;<code>PatternLayout</code> &#x53EF;&#x4EE5;&#x8BC6;&#x522B; &quot;%black&quot;&#xFF0C;&quot;%red&quot;&#xFF0C;&quot;%green&quot;&#xFF0C;&quot;%yellow&quot;&#xFF0C;&quot;%blue&quot;&#xFF0C;&quot;%magenta&quot;,&quot;%cyan&quot;, &quot;%white&quot;, &quot;%gray&quot;, &quot;%boldRed&quot;,&quot;%boldGreen&quot;, &quot;%boldYellow&quot;, &quot;%boldBlue&quot;, &quot;%boldMagenta&quot;&quot;%boldCyan&quot;, &quot;%boldWhite&quot; &#x4EE5;&#x53CA; &quot;%highlight&quot; &#x4F5C;&#x4E3A;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x3002;&#x8FD9;&#x4E9B;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x90FD;&#x8FD8;&#x53EF;&#x4EE5;&#x5305;&#x542B;&#x4E00;&#x4E2A;&#x5B50;&#x6A21;&#x5F0F;&#x3002;&#x4EFB;&#x4F55;&#x88AB;&#x989C;&#x8272;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x5305;&#x88F9;&#x7684;&#x5B50;&#x6A21;&#x5F0F;&#x90FD;&#x4F1A;&#x901A;&#x8FC7;&#x6307;&#x5B9A;&#x7684;&#x989C;&#x8272;&#x8F93;&#x51FA;&#x3002;</p>
<p>&#x4E0B;&#x9762;&#x662F;&#x5173;&#x4E8E;&#x7740;&#x8272;&#x7684;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#x3002;</p>
<pre><code class="lang-xml"><span class="hljs-tag">&lt;<span class="hljs-name">configuration</span> <span class="hljs-attr">debug</span>=<span class="hljs-string">&quot;true&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">appender</span> <span class="hljs-attr">name</span>=<span class="hljs-string">&quot;STDOUT&quot;</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.core.ConsoleAppender&quot;</span>&gt;</span>
<span class="hljs-comment">&lt;!--               &#x5728; Windows &#x5E73;&#x53F0;&#x4E0B;&#xFF0C;&#x8BBE;&#x7F6E; withJansi = true &#x6765;&#x5F00;&#x542F; ANSI &#x989C;&#x8272;&#x4EE3;&#x7801;&#x9700;&#x8981; Jansi &#x7C7B;&#x5E93; --&gt;</span>
<span class="hljs-comment">&lt;!--               &#x9700;&#x8981;&#x5728; classpath &#x5F15;&#x5165; org.fusesource.jansi:jansi:1.8 &#x5305; --&gt;</span>
<span class="hljs-comment">&lt;!--               &#x5728;&#x57FA;&#x4E8E; Unix &#x64CD;&#x4F5C;&#x7CFB;&#x7EDF;&#xFF0C;&#x50CF; Linux &#x4EE5;&#x53CA; Mac OS X &#x7CFB;&#x7EDF;&#x9ED8;&#x8BA4;&#x652F;&#x6301; ANSI &#x989C;&#x8272;&#x4EE3;&#x7801; --&gt;</span>
        <span class="hljs-tag">&lt;<span class="hljs-name">withJansi</span>&gt;</span>true<span class="hljs-tag">&lt;/<span class="hljs-name">withJansi</span>&gt;</span>
        <span class="hljs-tag">&lt;<span class="hljs-name">encoder</span>&gt;</span>
            <span class="hljs-tag">&lt;<span class="hljs-name">pattern</span>&gt;</span>[%thread] %highlight(%-5level) %cyan(%logger{15}) - %msg %n<span class="hljs-tag">&lt;/<span class="hljs-name">pattern</span>&gt;</span>
        <span class="hljs-tag">&lt;/<span class="hljs-name">encoder</span>&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">appender</span>&gt;</span>

    <span class="hljs-tag">&lt;<span class="hljs-name">root</span> <span class="hljs-attr">level</span>=<span class="hljs-string">&quot;DEBUG&quot;</span>&gt;</span>
        <span class="hljs-tag">&lt;<span class="hljs-name">appender-ref</span> <span class="hljs-attr">ref</span>=<span class="hljs-string">&quot;STDOUT&quot;</span> /&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">root</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">configuration</span>&gt;</span>
</code></pre>
<p>&#x4E0B;&#x9762;&#x662F;&#x76F8;&#x5173;&#x7684;&#x8F93;&#x51FA;&#xFF1A;</p>
<pre><code class="lang-java">[main] WARN  c.l.TrivialMain - a warning message <span class="hljs-number">0</span>
[main] DEBUG c.l.TrivialMain - hello world number1
[main] DEBUG c.l.TrivialMain - hello world number2
[main] INFO  c.l.TrivialMain - hello world number3
[main] DEBUG c.l.TrivialMain - hello world number4
[main] WARN  c.l.TrivialMain - a warning message <span class="hljs-number">5</span>
[main] ERROR c.l.TrivialMain - Finish off with fireworks
</code></pre>
<blockquote>
<p>  &#x5176;&#x5B9E;&#x662F;&#x6709;&#x989C;&#x8272;&#x7684;&#xFF0C;&#x4F46;&#x662F; md &#x4E0D;&#x652F;&#x6301;&#x76F4;&#x63A5;&#x5BF9;&#x5B57;&#x4F53;&#x989C;&#x8272;&#x8FDB;&#x884C;&#x64CD;&#x4F5C;&#xFF0C;&#x800C;&#x6211;&#x61D2;&#x5F97;&#x53BB;&#x6298;&#x817E; HTML </p>
</blockquote>
<p>&#x53EA;&#x9700;&#x8981;&#x51E0;&#x884C;&#x4EE3;&#x7801;&#x5C31;&#x53EF;&#x4EE5;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x7740;&#x8272;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x3002;&#x5728;&#x81EA;&#x5B9A;&#x4E49;&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;&#x90E8;&#x5206;&#xFF0C;&#x6211;&#x4EEC;&#x5C06;&#x8BA8;&#x8BBA;&#x600E;&#x6837;&#x5728;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#x4E2D;&#x6CE8;&#x518C;&#x4E00;&#x4E2A;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x3002;</p>
<h2 id="evaluators">Evaluators</h2>
<p>&#x50CF;&#x4E4B;&#x524D;&#x63D0;&#x5230;&#x7684;&#xFF0C;&#x5F53;&#x4E00;&#x4E2A;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x9700;&#x8981;&#x57FA;&#x4E8E;&#x4E00;&#x4E2A;&#x6216;&#x8005;&#x591A;&#x4E2A; <a href="https://logback.qos.ch/xref/ch/qos/logback/core/boolex/EventEvaluator.html" target="_blank"><code>EventEvaluator</code></a> &#x5BF9;&#x8C61;&#x52A8;&#x6001;&#x8868;&#x73B0;&#x65F6;&#xFF0C;<code>EventEvaluator</code> &#x5BF9;&#x8C61;&#x6839;&#x636E;&#x89C4;&#x5219;&#x53EF;&#x4EE5;&#x51B3;&#x5B9A;&#x7ED9;&#x5B9A;&#x7684;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x662F;&#x5426;&#x5339;&#x914D;&#x3002;</p>
<p>&#x8BA9;&#x6211;&#x4EEC;&#x6765;&#x56DE;&#x987E;&#x4E00;&#x4E0B;&#x5305;&#x542B; <code>EventEvaluator</code> &#x7684;&#x4F8B;&#x5B50;&#x3002;&#x4E0B;&#x4E00;&#x4E2A;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#x8F93;&#x51FA;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x5230;&#x63A7;&#x5236;&#x53F0;&#xFF0C;&#x663E;&#x793A;&#x65E5;&#x671F;&#xFF0C;&#x7EBF;&#x7A0B;&#xFF0C;&#x65E5;&#x5FD7;&#x7EA7;&#x522B;&#xFF0C;&#x6D88;&#x606F;&#xFF0C;&#x4EE5;&#x53CA;&#x8C03;&#x7528;&#x8005;&#x6570;&#x636E;&#x3002;&#x83B7;&#x53D6;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x8C03;&#x7528;&#x8005;&#x7684;&#x4FE1;&#x606F;&#x6210;&#x672C;&#x6BD4;&#x8F83;&#x9AD8;&#xFF0C;&#x53EA;&#x6709;&#x5F53;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#x6765;&#x6E90;&#x7279;&#x5B9A;&#x7684; logger&#xFF0C;&#x6216;&#x8005;&#x6D88;&#x606F;&#x5305;&#x542B;&#x7279;&#x5B9A;&#x7684;&#x5B57;&#x7B26;&#x4E32;&#x65F6;&#xFF0C;&#x6211;&#x4EEC;&#x624D;&#x4F1A;&#x8FD9;&#x6837;&#x505A;&#x3002;&#x6362;&#x53E5;&#x8BDD;&#x8BF4;&#xFF0C;&#x5728;&#x8C03;&#x7528;&#x8005;&#x4FE1;&#x606F;&#x662F;&#x591A;&#x4F59;&#x7684;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x6211;&#x4EEC;&#x4E0D;&#x5E94;&#x8BE5;&#x53BB;&#x5F71;&#x54CD;&#x5E94;&#x7528;&#x7684;&#x6027;&#x80FD;&#x3002;</p>
<p>Evaluator &#x4E0E; <em>&#x8BC4;&#x4EF7;&#x8868;&#x8FBE;&#x5F0F; (evaluation expressions)</em> &#x90FD;&#x4F1A;&#x5728;<a href="https://logback.qos.ch/manual/filters.html#evalutatorFilter" target="_blank">&#x7B2C;&#x4E03;&#x7AE0;</a> &#x8BE6;&#x7EC6;&#x4ECB;&#x7ECD;&#x3002;&#x5982;&#x679C;&#x4F60;&#x60F3;&#x5229;&#x7528; evaluator &#x53BB;&#x505A;&#x4E00;&#x4E9B;&#x6709;&#x610F;&#x601D;&#x7684;&#x4E8B;&#x60C5;&#xFF0C;&#x4F60;&#x5FC5;&#x987B;&#x770B;&#x4E00;&#x4E0B;&#x5BF9;&#x8FD9;&#x4E2A;&#x7684;&#x8BE6;&#x7EC6;&#x4ECB;&#x7ECD;&#x3002;&#x4E0B;&#x9762;&#x7684;&#x4F8B;&#x5B50;&#x57FA;&#x4E8E; <code>JaninoEventEvaluator</code>&#xFF0C;&#x6240;&#x4EE5;&#x9700;&#x8981; <a href="http://docs.codehaus.org/display/JANINO/Home" target="_blank">Janino &#x7C7B;&#x5E93;</a>&#x3002;&#x67E5;&#x770B;<a href="https://logback.qos.ch/setup.html#janino" target="_blank">&#x76F8;&#x5173;&#x6587;&#x6863;</a>&#x8FDB;&#x884C;&#x8BBE;&#x7F6E;&#x3002;</p>
<blockquote>
<p>  Example: <em>callerEvaluatorConfig.xml</em></p>
</blockquote>
<pre><code class="lang-xml"><span class="hljs-tag">&lt;<span class="hljs-name">configuration</span>&gt;</span>
  <span class="hljs-tag">&lt;<span class="hljs-name">evaluator</span> <span class="hljs-attr">name</span>=<span class="hljs-string">&quot;DISP_CALLER_EVAL&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">expression</span>&gt;</span>logger.contains(&quot;chapters.layouts&quot;) &amp;amp;&amp;amp; \
      message.contains(&quot;who calls thee&quot;)<span class="hljs-tag">&lt;/<span class="hljs-name">expression</span>&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">evaluator</span>&gt;</span>

  <span class="hljs-tag">&lt;<span class="hljs-name">appender</span> <span class="hljs-attr">name</span>=<span class="hljs-string">&quot;STDOUT&quot;</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.core.ConsoleAppender&quot;</span>&gt;</span> 
    <span class="hljs-tag">&lt;<span class="hljs-name">encoder</span>&gt;</span>
      <span class="hljs-tag">&lt;<span class="hljs-name">pattern</span>&gt;</span>
        %-4relative [%thread] %-5level - %msg%n%caller{2, DISP_CALLER_EVAL}
      <span class="hljs-tag">&lt;/<span class="hljs-name">pattern</span>&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">encoder</span>&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">appender</span>&gt;</span>

  <span class="hljs-tag">&lt;<span class="hljs-name">root</span> <span class="hljs-attr">level</span>=<span class="hljs-string">&quot;DEBUG&quot;</span>&gt;</span> 
    <span class="hljs-tag">&lt;<span class="hljs-name">appender-ref</span> <span class="hljs-attr">ref</span>=<span class="hljs-string">&quot;STDOUT&quot;</span> /&gt;</span> 
  <span class="hljs-tag">&lt;/<span class="hljs-name">root</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">configuration</span>&gt;</span>
</code></pre>
<p>&#x4E0A;&#x9762;&#x7684;&#x8BC4;&#x4EF7;&#x8868;&#x8FBE;&#x5F0F;&#x7528;&#x6765;&#x5339;&#x914D;&#x4ECE;&#x540D;&#x4E3A; &quot;chapters.layouts&quot; logger &#x53D1;&#x51FA;&#xFF0C;&#x5E76;&#x4E14;&#x6D88;&#x606F;&#x4E2D;&#x5305;&#x542B;&#x5B57;&#x7B26;&#x4E32; &quot;who calls thee&quot; &#x7684;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x3002;&#x7531;&#x4E8E; XML &#x7684;&#x7F16;&#x7801;&#x89C4;&#x5219;&#xFF0C;<code>&amp;</code> &#x7B26;&#x53F7;&#x9700;&#x8981;&#x88AB;&#x8F6C;&#x4E49;&#x4E3A; <code>&amp;amp;</code>&#x3002;</p>
<p>&#x4E0B;&#x9762;&#x7684;&#x7C7B;&#x5229;&#x7528;&#x4E86;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#x4E2D;&#x6240;&#x63D0;&#x5230;&#x7684;&#x7279;&#x6027;&#x3002;</p>
<blockquote>
<p>  Example: CallerEvaluatorExample.java</p>
</blockquote>
<pre><code class="lang-java"><span class="hljs-keyword">package</span> chapters.layouts;

<span class="hljs-keyword">import</span> org.slf4j.Logger;
<span class="hljs-keyword">import</span> org.slf4j.LoggerFactory;

<span class="hljs-keyword">import</span> ch.qos.logback.classic.LoggerContext;
<span class="hljs-keyword">import</span> ch.qos.logback.classic.joran.JoranConfigurator;
<span class="hljs-keyword">import</span> ch.qos.logback.core.joran.spi.JoranException;
<span class="hljs-keyword">import</span> ch.qos.logback.core.util.StatusPrinter;

<span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">CallerEvaluatorExample</span> </span>{

  <span class="hljs-function"><span class="hljs-keyword">public</span> <span class="hljs-keyword">static</span> <span class="hljs-keyword">void</span> <span class="hljs-title">main</span><span class="hljs-params">(String[] args)</span>  </span>{
    Logger logger = LoggerFactory.getLogger(CallerEvaluatorExample.class);
    LoggerContext lc = (LoggerContext) LoggerFactory.getILoggerFactory();

    <span class="hljs-keyword">try</span> {
      JoranConfigurator configurator = <span class="hljs-keyword">new</span> JoranConfigurator();
      configurator.setContext(lc);
      configurator.doConfigure(args[<span class="hljs-number">0</span>]);
    } <span class="hljs-keyword">catch</span> (JoranException je) {
      <span class="hljs-comment">// StatusPrinter will handle this</span>
    }
    StatusPrinter.printInCaseOfErrorsOrWarnings(lc);

    <span class="hljs-keyword">for</span> (<span class="hljs-keyword">int</span> i = <span class="hljs-number">0</span>; i &lt; <span class="hljs-number">5</span>; i++) {
      <span class="hljs-keyword">if</span> (i == <span class="hljs-number">3</span>) {
        logger.debug(<span class="hljs-string">&quot;who calls thee?&quot;</span>);
      } <span class="hljs-keyword">else</span> {
        logger.debug(<span class="hljs-string">&quot;I know me &quot;</span> + i);
      }
    }
  }
}
</code></pre>
<p>&#x4E0A;&#x9762;&#x7684;&#x5E94;&#x7528;&#x6CA1;&#x6709;&#x4EC0;&#x4E48;&#x7279;&#x522B;&#x7684;&#x5730;&#x65B9;&#x3002;&#x53D1;&#x51FA;&#x4E94;&#x6761;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#xFF0C;&#x7B2C;&#x4E09;&#x6761;&#x7684;&#x7684;&#x8BF7;&#x6C42;&#x4FE1;&#x606F;&#x4E3A; &quot;who calls thee?&quot;&#x3002;</p>
<p>&#x901A;&#x8FC7;&#x547D;&#x4EE4;&#xFF1A;</p>
<pre><code class="lang-bash">java chapters.layouts.CallerEvaluatorExample src/main/java/chapters/layouts/<span class="hljs-built_in">caller</span>EvaluatorConfig.xml
</code></pre>
<p>&#x5C06;&#x4F1A;&#x8F93;&#x51FA;&#xFF1A;</p>
<pre><code class="lang-java"><span class="hljs-number">0</span>    [main] DEBUG - I know me <span class="hljs-number">0</span> 
<span class="hljs-number">0</span>    [main] DEBUG - I know me <span class="hljs-number">1</span> 
<span class="hljs-number">0</span>    [main] DEBUG - I know me <span class="hljs-number">2</span> 
<span class="hljs-number">0</span>    [main] DEBUG - who calls thee? 
Caller+<span class="hljs-number">0</span>   at chapters.layouts.CallerEvaluatorExample.main(CallerEvaluatorExample.java:<span class="hljs-number">28</span>)
<span class="hljs-number">0</span>    [main] DEBUG - I know me <span class="hljs-number">4</span>
</code></pre>
<p>&#x5F53;&#x53D1;&#x51FA;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#x65F6;&#xFF0C;&#x4F1A;&#x8BC4;&#x4EF7;&#x76F8;&#x5E94;&#x7684;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x3002;&#x4EC5;&#x4EC5;&#x53EA;&#x6709;&#x7B2C;&#x4E09;&#x4E2A;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x4F1A;&#x5339;&#x914D;&#x5230;&#x8BC4;&#x4EF7;&#x89C4;&#x5219;&#xFF0C;&#x6240;&#x4EE5;&#x5B83;&#x7684;&#x8C03;&#x7528;&#x8005;&#x4FE1;&#x606F;&#x4F1A;&#x88AB;&#x5C55;&#x793A;&#x51FA;&#x6765;&#x3002;&#x5BF9;&#x4E8E;&#x5176;&#x5B83;&#x7684;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#xFF0C;&#x7531;&#x4E8E;&#x6CA1;&#x6709;&#x5339;&#x914D;&#x5230;&#x8BC4;&#x4EF7;&#x89C4;&#x5219;&#xFF0C;&#x8C03;&#x7528;&#x8005;&#x4FE1;&#x606F;&#x4E0D;&#x4F1A;&#x88AB;&#x6253;&#x5370;&#x3002;</p>
<p>&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x66F4;&#x6539;&#x8868;&#x8FBE;&#x5F0F;&#x6765;&#x5E94;&#x5BF9;&#x771F;&#x5B9E;&#x7684;&#x5E94;&#x7528;&#x573A;&#x666F;&#x3002;&#x4E3E;&#x4E2A;&#x1F330;&#xFF0C;&#x4F60;&#x53EF;&#x4EE5;&#x7ED3;&#x5408; logger &#x540D;&#x4E0E;&#x65E5;&#x5FD7;&#x7EA7;&#x522B;&#xFF0C;&#x65E5;&#x5FD7;&#x7EA7;&#x522B;&#x5728; <em>WARN</em> &#x4EE5;&#x4E0A;&#x7684;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#x88AB;&#x5F53;&#x4F5C;&#x4E00;&#x4E2A;&#x654F;&#x611F;&#x7684;&#x90E8;&#x5206;&#xFF0C;&#x5728;&#x91D1;&#x878D;&#x4E1A;&#x52A1;&#x6A21;&#x5757;&#x4E2D;&#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x8FD9;&#x6837;&#x505A;&#x6765;&#x83B7;&#x53D6;&#x8C03;&#x7528;&#x8005;&#x7684;&#x4FE1;&#x606F;&#x3002;</p>
<p><strong>&#x91CD;&#x8981;&#xFF1A;</strong>&#x5F53;<em>&#x8BC4;&#x4EF7;&#x8868;&#x8FBE;&#x5F0F;</em>&#x4E3A; <strong>true</strong> &#x65F6;&#xFF0C;&#x901A;&#x8FC7; <em>caller</em> &#x8F6C;&#x6362;&#x5B57;&#x7B26;&#xFF0C;&#x53EF;&#x4EE5;&#x8F93;&#x51FA;&#x8C03;&#x7528;&#x8005;&#x7684;&#x4FE1;&#x606F;&#x3002;</p>
<p>&#x8003;&#x8651;&#x8FD9;&#x4E48;&#x4E00;&#x79CD;&#x60C5;&#x51B5;&#xFF0C;&#x5F53;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#x4E2D;&#x5305;&#x542B;&#x5F02;&#x5E38;&#x4FE1;&#x606F;&#x65F6;&#xFF0C;&#x5B83;&#x4EEC;&#x7684;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x4E5F;&#x4F1A;&#x8F93;&#x51FA;&#x3002;&#x4F46;&#x662F;&#xFF0C;&#x5BF9;&#x4E8E;&#x67D0;&#x4E9B;&#x7279;&#x5B9A;&#x7684;&#x5F02;&#x5E38;&#x4FE1;&#x606F;&#xFF0C;&#x53EF;&#x80FD;&#x9700;&#x8981;&#x7981;&#x6B62;&#x8F93;&#x51FA;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x3002;</p>
<p>&#x4E0B;&#x9762;&#x7684;&#x4EE3;&#x7801;&#x521B;&#x5EFA;&#x4E86;&#x4E09;&#x6761;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#xFF0C;&#x6BCF;&#x4E00;&#x6761;&#x90FD;&#x5305;&#x542B;&#x4E00;&#x4E2A;&#x5F02;&#x5E38;&#x4FE1;&#x606F;&#x3002;&#x7B2C;&#x4E8C;&#x6761;&#x7684;&#x5F02;&#x5E38;&#x4FE1;&#x606F;&#x8DDF;&#x5176;&#x5B83;&#x7684;&#x4E0D;&#x4E00;&#x6837;&#xFF0C;&#x5B83;&#x5305;&#x542B; &quot;do not display this&quot; &#x5B57;&#x7B26;&#x4E32;&#xFF0C;&#x5E76;&#x4E14;&#x5B83;&#x7684;&#x5F02;&#x5E38;&#x4FE1;&#x606F;&#x7C7B;&#x578B;&#x4E3A; <code>chapters.layouts.TestException</code>&#x3002;&#x73B0;&#x5728;&#x8BA9;&#x6211;&#x4EEC;&#x6765;&#x963B;&#x6B62;&#x7B2C;&#x4E8C;&#x6761;&#x65E5;&#x5FD7;&#x7684;&#x6253;&#x5370;&#x3002;</p>
<blockquote>
<p>  Example: <em>ExceptionEvaluatorExample.java</em></p>
</blockquote>
<pre><code class="lang-java"><span class="hljs-keyword">package</span> chapters.layouts;

<span class="hljs-keyword">import</span> org.slf4j.Logger;
<span class="hljs-keyword">import</span> org.slf4j.LoggerFactory;

<span class="hljs-keyword">import</span> ch.qos.logback.classic.LoggerContext;
<span class="hljs-keyword">import</span> ch.qos.logback.classic.joran.JoranConfigurator;
<span class="hljs-keyword">import</span> ch.qos.logback.core.joran.spi.JoranException;
<span class="hljs-keyword">import</span> ch.qos.logback.core.util.StatusPrinter;

<span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">ExceptionEvaluatorExample</span> </span>{

  <span class="hljs-function"><span class="hljs-keyword">public</span> <span class="hljs-keyword">static</span> <span class="hljs-keyword">void</span> <span class="hljs-title">main</span><span class="hljs-params">(String[] args)</span> </span>{
    Logger logger = LoggerFactory.getLogger(ExceptionEvaluatorExample.class);
    LoggerContext lc = (LoggerContext) LoggerFactory.getILoggerFactory();

    <span class="hljs-keyword">try</span> {
      JoranConfigurator configurator = <span class="hljs-keyword">new</span> JoranConfigurator();
      configurator.setContext(lc);
      lc.reset();
      configurator.doConfigure(args[<span class="hljs-number">0</span>]);
    } <span class="hljs-keyword">catch</span> (JoranException je) {
       <span class="hljs-comment">// StatusPrinter will handle this</span>
    }
    StatusPrinter.printInCaseOfErrorsOrWarnings(lc);

    <span class="hljs-keyword">for</span> (<span class="hljs-keyword">int</span> i = <span class="hljs-number">0</span>; i &lt; <span class="hljs-number">3</span>; i++) {
      <span class="hljs-keyword">if</span> (i == <span class="hljs-number">1</span>) {
        logger.debug(<span class="hljs-string">&quot;logging statement &quot;</span> + i, <span class="hljs-keyword">new</span> TestException(
            <span class="hljs-string">&quot;do not display this&quot;</span>));
      } <span class="hljs-keyword">else</span> {
        logger.debug(<span class="hljs-string">&quot;logging statement &quot;</span> + i, <span class="hljs-keyword">new</span> Exception(<span class="hljs-string">&quot;display&quot;</span>));
      }
    }
  }
}
</code></pre>
<p>&#x4E0B;&#x9762;&#x7684;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#x901A;&#x8FC7;&#x8BC4;&#x4EF7;&#x8868;&#x8FBE;&#x5F0F;&#x6765;&#x5339;&#x914D;&#x5305;&#x542B; <code>chapters.layouts.TextException</code> &#x7C7B;&#x578B;&#x7684;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#xFF0C;&#x4E5F;&#x5C31;&#x662F;&#x6211;&#x4EEC;&#x4E4B;&#x524D;&#x8BF4;&#x8981;&#x7981;&#x6B62;&#x7684;&#x5F02;&#x5E38;&#x7C7B;&#x578B;&#x3002;</p>
<blockquote>
<p>  Example: <em>exceptionEvaluatorConfig.xml</em></p>
</blockquote>
<pre><code class="lang-xml"><span class="hljs-tag">&lt;<span class="hljs-name">configuration</span>&gt;</span>
  <span class="hljs-comment">&lt;!-- evaluator &#x9700;&#x8981;&#x5728; appender &#x524D;&#x9762;&#x5B9A;&#x4E49; --&gt;</span>
  <span class="hljs-tag">&lt;<span class="hljs-name">evaluator</span> <span class="hljs-attr">name</span>=<span class="hljs-string">&quot;DISPLAY_EX_EVAL&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">expression</span>&gt;</span>throwable != null &amp;amp;&amp;amp; throwable instanceof  \
      chapters.layouts.TestException<span class="hljs-tag">&lt;/<span class="hljs-name">expression</span>&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">evaluator</span>&gt;</span>

  <span class="hljs-tag">&lt;<span class="hljs-name">appender</span> <span class="hljs-attr">name</span>=<span class="hljs-string">&quot;STDOUT&quot;</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.core.ConsoleAppender&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">encoder</span>&gt;</span>
      <span class="hljs-tag">&lt;<span class="hljs-name">pattern</span>&gt;</span>%msg%n%xEx{full, DISPLAY_EX_EVAL}<span class="hljs-tag">&lt;/<span class="hljs-name">pattern</span>&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">encoder</span>&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">appender</span>&gt;</span>

  <span class="hljs-tag">&lt;<span class="hljs-name">root</span> <span class="hljs-attr">level</span>=<span class="hljs-string">&quot;debug&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">appender-ref</span> <span class="hljs-attr">ref</span>=<span class="hljs-string">&quot;STDOUT&quot;</span> /&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">root</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">configuration</span>&gt;</span>
</code></pre>
<blockquote>
<p>  &#x4F5C;&#x8005;&#x539F;&#x6587;&#x91CC;&#x9762;&#x662F; %ex&#xFF0C;&#x5E94;&#x8BE5;&#x662F;&#x7B14;&#x8BEF;</p>
</blockquote>
<p>&#x901A;&#x8FC7;&#x8FD9;&#x4E2A;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#xFF0C;&#x6BCF;&#x5F53;&#x65E5;&#x5FD7;&#x8BF7;&#x6C42;&#x4E2D;&#x5305;&#x542B;&#x4E00;&#x4E2A; <em>chapters.layouts.TestException</em> &#x65F6;&#xFF0C;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x4E0D;&#x4F1A;&#x88AB;&#x8F93;&#x51FA;&#x3002;</p>
<p>&#x901A;&#x8FC7;&#x5982;&#x4E0B;&#x547D;&#x4EE4;&#x542F;&#x52A8;&#xFF1A;</p>
<pre><code class="lang-bash">java chapters.layouts.ExceptionEvaluatorExample src/main/java/chapters/layouts/exceptionEvaluatorConfig.xml
</code></pre>
<p>&#x5C06;&#x4F1A;&#x8F93;&#x51FA;&#xFF1A;</p>
<pre><code class="lang-java">logging statement <span class="hljs-number">0</span>
java.lang.Exception: display
    at chapters.layouts.ExceptionEvaluatorExample.main(ExceptionEvaluatorExample.java:<span class="hljs-number">16</span>)
logging statement <span class="hljs-number">1</span>
logging statement <span class="hljs-number">2</span>
java.lang.Exception: display
    at chapters.layouts.ExceptionEvaluatorExample.main(ExceptionEvaluatorExample.java:<span class="hljs-number">16</span>)
</code></pre>
<blockquote>
<p>  &#x4F5C;&#x8005;&#x539F;&#x6587;&#x8FD8;&#x8F93;&#x51FA;&#x4E86; jar &#x5305;&#x7684;&#x4FE1;&#x606F;&#xFF0C;&#x662F;&#x56E0;&#x4E3A;&#x6253;&#x5305;&#x540E;&#x901A;&#x8FC7;&#x547D;&#x4EE4;&#x884C;&#x6267;&#x884C;&#x7684; (I think &#x1F602;)</p>
</blockquote>
<p>&#x7B2C;&#x4E8C;&#x6761;&#x65E5;&#x5FD7;&#x6CA1;&#x6709;&#x5806;&#x6808;&#x4FE1;&#x606F;&#xFF0C;&#x56E0;&#x4E3A;&#x6211;&#x4EEC;&#x7981;&#x6B62; <code>TextException</code> &#x7C7B;&#x578B;&#x7684;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x3002;&#x6BCF;&#x6761;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x7684;&#x6700;&#x540E;&#x7528;&#x7EFC;&#x62EC;&#x53F7;&#x5305;&#x88F9;&#x8D77;&#x6765;&#x7684;&#x662F;&#x5177;&#x4F53;&#x7684;<a href="https://github.com/Volong/logback-chinese-manual/blob/master/06%E7%AC%AC%E5%85%AD%E7%AB%A0%EF%BC%9ALayout.md#xThrowable" target="_blank">&#x5305;&#x4FE1;&#x606F;</a>&#x3002;</p>
<p><strong><code>&#x6CE8;&#x610F;&#xFF1A;</code></strong> &#x5F53; <strong>%ex</strong> &#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;&#x4E2D;&#x7684;&#x8BC4;&#x4EF7;&#x8868;&#x8FBE;&#x5F0F;&#x4E3A; <strong>false</strong> &#x65F6;&#xFF0C;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x624D;&#x4F1A;&#x8F93;&#x51FA;&#x3002;</p>
<h2 id="&#x81EA;&#x5B9A;&#x4E49;&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;">&#x81EA;&#x5B9A;&#x4E49;&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;</h2>
<p>&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x5728; <code>PatternLayout</code> &#x4E2D;&#x4F7F;&#x7528;&#x5185;&#x7F6E;&#x7684;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x3002;&#x6211;&#x4EEC;&#x4E5F;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x81EA;&#x5DF1;&#x65B0;&#x5EFA;&#x7684;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x3002;</p>
<p>&#x65B0;&#x5EFA;&#x4E00;&#x4E2A;&#x81EA;&#x5B9A;&#x4E49;&#x7684;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x9700;&#x8981;&#x4E24;&#x6B65;&#x3002;</p>
<h4 id="&#x7B2C;&#x4E00;&#x6B65;">&#x7B2C;&#x4E00;&#x6B65;</h4>
<p>&#x9996;&#x5148;&#xFF0C;&#x4F60;&#x5FC5;&#x987B;&#x7EE7;&#x627F; <code>ClassicConverter</code> &#x7C7B;&#x3002;<a href="https://logback.qos.ch/xref/ch/qos/logback/classic/pattern/ClassicConverter.html" target="_blank"><code>ClassicConverter</code></a> &#x5BF9;&#x8C61;&#x8D1F;&#x8D23;&#x4ECE; <code>ILoggingEvent</code> &#x5B9E;&#x4F8B;&#x4E2D;&#x62BD;&#x53D6;&#x4FE1;&#x606F;&#x5E76;&#x8F93;&#x51FA;&#x5B57;&#x7B26;&#x4E32;&#x3002;&#x4F8B;&#x5982;&#xFF0C;%logger &#x5BF9;&#x5E94;&#x7684;&#x8F6C;&#x6362;&#x5668; <a href="https://logback.qos.ch/xref/ch/qos/logback/classic/pattern/LoggerConverter.html" target="_blank"><code>LoggerConverter</code></a>&#xFF0C;&#x53EF;&#x4EE5;&#x4ECE; <code>ILoggingEvent</code> &#x4ECE;&#x62BD;&#x53D6; logger &#x7684;&#x540D;&#x5B57;&#xFF0C;&#x8FD4;&#x56DE;&#x4E00;&#x4E2A;&#x5B57;&#x7B26;&#x4E32;&#x3002;&#x5B83;&#x53EF;&#x4EE5;&#x7F29;&#x5199; logger &#x7684;&#x540D;&#x5B57;&#x3002;</p>
<p>&#x4E0B;&#x9762;&#x662F;&#x4E00;&#x4E2A;&#x81EA;&#x5B9A;&#x4E49;&#x7684;&#x8F6C;&#x6362;&#x5668;&#xFF0C;&#x8FD4;&#x56DE;&#x4ECE;&#x521B;&#x5EFA;&#x5F00;&#x59CB;&#x7ECF;&#x8FC7;&#x7684;&#x65F6;&#x95F4;&#xFF0C;&#x5355;&#x4F4D;&#x4E3A;&#x7EB3;&#x79D2;&#x3002;</p>
<blockquote>
<p>Example: MySampleConverter</p>
</blockquote>
<pre><code class="lang-java"><span class="hljs-keyword">public</span> <span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">MySampleConverter</span> <span class="hljs-keyword">extends</span> <span class="hljs-title">ClassicConverter</span> </span>{

  <span class="hljs-keyword">long</span> start = System.nanoTime();

  <span class="hljs-meta">@Override</span>
  <span class="hljs-function"><span class="hljs-keyword">public</span> String <span class="hljs-title">convert</span><span class="hljs-params">(ILoggingEvent event)</span> </span>{
    <span class="hljs-keyword">long</span> nowInNanos = System.nanoTime();
    <span class="hljs-keyword">return</span> Long.toString(nowInNanos-start);
  }
}
</code></pre>
<p>&#x8FD9;&#x4E2A;&#x5B9E;&#x73B0;&#x975E;&#x5E38;&#x7B80;&#x5355;&#x3002;<code>MySampleConverter</code> &#x7EE7;&#x627F;&#x4E86; <code>ClassicConverter</code> &#x5E76;&#x5B9E;&#x73B0;&#x4E86; <code>convert</code> &#x65B9;&#x6CD5;&#xFF0C;&#x8FD4;&#x56DE;&#x4ECE;&#x521B;&#x5EFA;&#x5F00;&#x59CB;&#x7ECF;&#x8FC7;&#x591A;&#x5C11;&#x7EB3;&#x79D2;&#x3002;</p>
<h4 id="&#x7B2C;&#x4E8C;&#x6B65;">&#x7B2C;&#x4E8C;&#x6B65;</h4>
<p>&#x7B2C;&#x4E8C;&#x6B65;&#xFF0C;&#x6211;&#x4EEC;&#x5FC5;&#x987B;&#x8BA9; logback &#x77E5;&#x9053;&#x8FD9;&#x4E2A;&#x65B0;&#x5EFA;&#x7684; <code>Converter</code>&#x3002;&#x6240;&#x4EE5;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x5728;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#x4E2D;&#x8FDB;&#x884C;&#x58F0;&#x660E;&#xFF0C;&#x5982;&#x4E0B;&#xFF1A;</p>
<blockquote>
<p>Example: <em>mySampleConverterConfig.xml</em></p>
</blockquote>
<pre><code class="lang-xml"><span class="hljs-tag">&lt;<span class="hljs-name">configuration</span>&gt;</span>

  <span class="hljs-tag">&lt;<span class="hljs-name">conversionRule</span> <span class="hljs-attr">conversionWord</span>=<span class="hljs-string">&quot;nanos&quot;</span> 
                  <span class="hljs-attr">converterClass</span>=<span class="hljs-string">&quot;chapters.layouts.MySampleConverter&quot;</span> /&gt;</span>

  <span class="hljs-tag">&lt;<span class="hljs-name">appender</span> <span class="hljs-attr">name</span>=<span class="hljs-string">&quot;STDOUT&quot;</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.core.ConsoleAppender&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">encoder</span>&gt;</span>
      <span class="hljs-tag">&lt;<span class="hljs-name">pattern</span>&gt;</span>%-6nanos [%thread] - %msg%n<span class="hljs-tag">&lt;/<span class="hljs-name">pattern</span>&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">encoder</span>&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">appender</span>&gt;</span>

  <span class="hljs-tag">&lt;<span class="hljs-name">root</span> <span class="hljs-attr">level</span>=<span class="hljs-string">&quot;DEBUG&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">appender-ref</span> <span class="hljs-attr">ref</span>=<span class="hljs-string">&quot;STDOUT&quot;</span> /&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">root</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">configuration</span>&gt;</span>
</code></pre>
<p>&#x6267;&#x884C;&#x547D;&#x4EE4;&#x5982;&#x4E0B;&#xFF1A;</p>
<pre><code class="lang-bash">java chapters.layouts.SampleLogging src/main/java/chapters/layouts/mySampleConverterConfig.xml
</code></pre>
<p>&#x8F93;&#x51FA;&#x4FE1;&#x606F;&#x5982;&#x4E0B;&#xFF1A;</p>
<pre><code class="lang-java">26113953 [main] - Everything&apos;s going well
26672034 [main] - maybe not quite...
</code></pre>
<p>&#x53EF;&#x4EE5;&#x770B;&#x4E00;&#x4E0B;&#x5176;&#x5B83; <code>Converter</code> &#x7684;&#x5B9E;&#x73B0;&#xFF0C;&#x4F8B;&#x5982; <a href="https://logback.qos.ch/xref/ch/qos/logback/classic/pattern/MDCConverter.html" target="_blank"><code>MDCConverter</code></a> &#xFF0C;&#x53BB;&#x5B9A;&#x5236;&#x66F4;&#x52A0;&#x590D;&#x6742;&#x7684;&#x529F;&#x80FD;&#xFF0C;&#x5982;&#x53EF;&#x9009;&#x5904;&#x7406;&#x3002;&#x60F3;&#x521B;&#x5EFA;&#x81EA;&#x5DF1;&#x7684;&#x989C;&#x8272;&#x4E3B;&#x9898;&#xFF0C;&#x53EF;&#x4EE5;&#x770B;&#x4E00;&#x4E0B; <a href="https://logback.qos.ch/xref/ch/qos/logback/classic/pattern/color/HighlightingCompositeConverter.html" target="_blank"><code>HighlightingCompositeConverter</code></a>&#x3002;</p>
<h2 id="htmllayout">HTMLLayout</h2>
<p><a href="https://logback.qos.ch/xref/ch/qos/logback/classic/html/HTMLLayout.html" target="_blank"><code>HTMLLayout</code></a> (&#x5305;&#x542B;&#x5728; logback-classic &#x4E2D;) &#x4EE5; HTML &#x683C;&#x5F0F;&#x751F;&#x6210;&#x65E5;&#x5FD7;&#x3002;<code>HTMLLayout</code> &#x901A;&#x8FC7; HTML &#x8868;&#x683C;&#x8F93;&#x51FA;&#x65E5;&#x5FD7;&#xFF0C;&#x6BCF;&#x4E00;&#x884C;&#x5BF9;&#x5E94;&#x4E00;&#x6761;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x3002;</p>
<p>&#x4E0B;&#x9762;&#x662F; <code>HTMLLayout</code> &#x901A;&#x8FC7;&#x9ED8;&#x8BA4;&#x7684; CSS &#x6837;&#x5F0F;&#x751F;&#x6210;&#x7684;&#x3002;</p>
<p><img src="images/htmlLayout0.gif" alt=""></p>
<p>&#x8868;&#x683C;&#x7684;&#x5217;&#x662F;&#x901A;&#x8FC7;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x6307;&#x5B9A;&#x7684;&#x3002;&#x5173;&#x4E8E;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x7684;&#x6587;&#x6863;&#x8BF7;&#x67E5;&#x770B; <a href="https://github.com/Volong/logback-chinese-manual/blob/34f5a61965088f0fa6d0d2a7e0e7085160e95201/06%E7%AC%AC%E5%85%AD%E7%AB%A0%EF%BC%9ALayouts.md#patternlayout" target="_blank">PatternLayout</a>&#x3002;&#x6240;&#x4EE5;&#xFF0C;&#x4F60;&#x53EF;&#x4EE5;&#x5B8C;&#x5168;&#x63A7;&#x5236;&#x8868;&#x683C;&#x7684;&#x5185;&#x5BB9;&#x4EE5;&#x53CA;&#x683C;&#x5F0F;&#x3002;&#x4F60;&#x53EF;&#x4EE5;&#x9009;&#x62E9;&#x5E76;&#x4E14;&#x5C55;&#x793A;&#x4EFB;&#x4F55;&#x8DDF; <code>PatternLayout</code> &#x7EC4;&#x5408;&#x7684;&#x8F6C;&#x6362;&#x5668;&#x3002;</p>
<p>&#x4E00;&#x4E2A;&#x503C;&#x5F97;&#x6CE8;&#x610F;&#x7684;&#x95EE;&#x9898;&#x662F;&#x4F7F;&#x7528; <code>PatternLayout</code> &#x4E2D;&#x7684; <code>HTMLLayout</code> &#x65F6;&#xFF0C;&#x4E0D;&#x8981;&#x4F7F;&#x7528;&#x7A7A;&#x683C;&#x6216;&#x8005;&#x5176;&#x5B83;&#x7684;&#x5B57;&#x9762;&#x91CF;&#x6765;&#x5206;&#x9694;&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;&#x3002;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x4E2D;&#x7684;&#x6BCF;&#x4E2A;&#x8BF4;&#x660E;&#x7B26;&#x90FD;&#x4F1A;&#x88AB;&#x5F53;&#x505A;&#x4E00;&#x4E2A;&#x5355;&#x72EC;&#x7684;&#x5217;&#x3002;&#x540C;&#x6837;&#x7684;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;&#x4E2D;&#x7684;&#x6BCF;&#x4E2A;&#x6587;&#x672C;&#x5757;&#x4E5F;&#x4F1A;&#x88AB;&#x5F53;&#x4F5C;&#x4E00;&#x4E2A;&#x5355;&#x72EC;&#x7684;&#x5217;&#xFF0C;&#x8FD9;&#x4F1A;&#x5360;&#x7528;&#x5C4F;&#x5E55;&#x7684;&#x7A7A;&#x95F4;&#x3002;</p>
<p>&#x4E0B;&#x9762;&#x7684; <code>HTMLLayout</code> &#x76F8;&#x5173;&#x7684;&#x914D;&#x7F6E;&#xFF1A;</p>
<blockquote>
<p>Example: <em>htmlLayoutConfig1.xml</em></p>
</blockquote>
<pre><code class="lang-xml"><span class="hljs-tag">&lt;<span class="hljs-name">configuration</span> <span class="hljs-attr">debug</span>=<span class="hljs-string">&quot;true&quot;</span>&gt;</span>
  <span class="hljs-tag">&lt;<span class="hljs-name">appender</span> <span class="hljs-attr">name</span>=<span class="hljs-string">&quot;FILE&quot;</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.core.FileAppender&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">encoder</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.core.encoder.LayoutWrappingEncoder&quot;</span>&gt;</span>
      <span class="hljs-tag">&lt;<span class="hljs-name">layout</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.classic.html.HTMLLayout&quot;</span>&gt;</span>
        <span class="hljs-tag">&lt;<span class="hljs-name">pattern</span>&gt;</span>%relative%thread%mdc%level%logger%msg<span class="hljs-tag">&lt;/<span class="hljs-name">pattern</span>&gt;</span>
      <span class="hljs-tag">&lt;/<span class="hljs-name">layout</span>&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">encoder</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">file</span>&gt;</span>test.html<span class="hljs-tag">&lt;/<span class="hljs-name">file</span>&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">appender</span>&gt;</span>

  <span class="hljs-tag">&lt;<span class="hljs-name">root</span> <span class="hljs-attr">level</span>=<span class="hljs-string">&quot;DEBUG&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">appender-ref</span> <span class="hljs-attr">ref</span>=<span class="hljs-string">&quot;FILE&quot;</span> /&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">root</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">configuration</span>&gt;</span>
</code></pre>
<p><a href="https://logback.qos.ch/xref/chapters/layouts/TrivialMain.html" target="_blank">TrivialMain</a> &#x5305;&#x542B;&#x4E00;&#x4E9B;&#x6D88;&#x606F;&#x4EE5;&#x53CA;&#x4E00;&#x4E2A;&#x7ED3;&#x675F;&#x5F02;&#x5E38;&#x3002;&#x6267;&#x884C;&#x4EE5;&#x4E0B;&#x547D;&#x4EE4;&#xFF1A;</p>
<pre><code class="lang-bash">java chapters.layouts.TrivialMain src/main/java/chapters/layouts/htmlLayoutConfig1.xml
</code></pre>
<p>&#x5C06;&#x4F1A;&#x5F53;&#x524D;&#x6587;&#x4EF6;&#x5939;&#x521B;&#x5EFA;&#x4E00;&#x4E2A; <em>test.html</em> &#x6587;&#x4EF6;&#x3002;<em>test.html</em> &#x6587;&#x4EF6;&#x7684;&#x5185;&#x5BB9;&#x4E0E;&#x4E0B;&#x9762;&#x7C7B;&#x4F3C;&#xFF1A;</p>
<p><img src="images/htmlLayout1.png" alt=""></p>
<h3 id="&#x5806;&#x6808;&#x4FE1;&#x606F;">&#x5806;&#x6808;&#x4FE1;&#x606F;</h3>
<p>&#x5982;&#x679C;&#x4F60;&#x4F7F;&#x7528; <em>%ex</em> &#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x53BB;&#x5C55;&#x793A;&#x5806;&#x6808;&#x4FE1;&#x606F;&#xFF0C;&#x90A3;&#x4E48;&#x5C06;&#x4F1A;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x5217;&#x6765;&#x5C55;&#x793A;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x3002;&#x5728;&#x5927;&#x591A;&#x6570;&#x7684;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x5217;&#x4F1A;&#x4E3A;&#x7A7A;&#xFF0C;&#x90A3;&#x4E48;&#x5C31;&#x4F1A;&#x6D6A;&#x8D39;&#x5C4F;&#x5E55;&#x7684;&#x7A7A;&#x95F4;&#x3002;&#x800C;&#x4E14;&#xFF0C;&#x5728;&#x5355;&#x72EC;&#x7684;&#x5217;&#x6253;&#x5370;&#x5806;&#x6808;&#x4FE1;&#x606F;&#xFF0C;&#x8F93;&#x51FA;&#x7684;&#x7ED3;&#x679C;&#x9605;&#x8BFB;&#x8D77;&#x6765;&#x6709;&#x96BE;&#x5EA6;&#x3002;&#x4F46;&#x662F;&#xFF0C;<em>%ex</em> &#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x4E0D;&#x662F;&#x552F;&#x4E00;&#x4E00;&#x4E2A;&#x7528;&#x6765;&#x5C55;&#x793A;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x7684;&#x3002;</p>
<blockquote>
<p>  &#x539F;&#x6587;&#x7B2C;&#x4E00;&#x4E2A; %ex &#x4E3A; %em</p>
</blockquote>
<p>&#x4E00;&#x4E2A;&#x66F4;&#x597D;&#x7684;&#x89E3;&#x51B3;&#x529E;&#x6CD5;&#x662F;&#x901A;&#x8FC7;&#x5B9E;&#x73B0; <code>IThrowableRenderer</code> &#x63A5;&#x53E3;&#x3002;&#x5B9E;&#x73B0;&#x7684;&#x63A5;&#x53E3;&#x53EF;&#x4EE5;&#x5206;&#x914D;&#x7ED9; <code>HTMLLayout</code> &#x6765;&#x7BA1;&#x7406;&#x76F8;&#x5173;&#x7684;&#x5F02;&#x5E38;&#x6570;&#x636E;&#x3002;&#x9ED8;&#x8BA4;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x4F1A;&#x7ED9;&#x6BCF;&#x4E2A; <code>HTMLLayout</code> &#x5B9E;&#x4F8B;&#x5206;&#x914D;&#x4E00;&#x4E2A; <a href="https://logback.qos.ch/xref/ch/qos/logback/classic/html/DefaultThrowableRenderer.html" target="_blank"><code>DefaultThrowableRenderer</code></a>&#x3002;&#x5B83;&#x5C06;&#x5F02;&#x5E38;&#x7684;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x5199;&#x5165;&#x5230;&#x8868;&#x683C;&#x65B0;&#x7684;&#x4E00;&#x884C;&#xFF0C;&#x5E76;&#x4E14;&#x975E;&#x5E38;&#x6613;&#x8BFB;&#xFF0C;&#x5C31;&#x8DDF;&#x4E0A;&#x9762;&#x5C55;&#x793A;&#x7684;&#x8868;&#x683C;&#x4E00;&#x6837;&#x3002;</p>
<p>&#x5982;&#x679C;&#x5728;&#x67D0;&#x4E9B;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x4F60;&#x4ECD;&#x7136;&#x60F3;&#x8981;&#x4F7F;&#x7528; <em>%ex</em>&#xFF0C;&#x90A3;&#x4E48;&#x4F60;&#x53EF;&#x4EE5;&#x5728;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#x4E2D;&#x6307;&#x5B9A; <a href="https://logback.qos.ch/xref/ch/qos/logback/core/html/NOPThrowableRenderer.html" target="_blank"><code>NOPThrowableRenderer</code></a> &#x6765;&#x7981;&#x6B62;&#x5728;&#x5355;&#x72EC;&#x4E00;&#x884C;&#x5C55;&#x793A;&#x5806;&#x6808;&#x4FE1;&#x606F;&#x3002;&#x6211;&#x4EEC;&#x4E0D;&#x7406;&#x89E3;&#x4E3A;&#x4EC0;&#x4E48;&#x4F60;&#x8981;&#x8FD9;&#x6837;&#x505A;&#xFF0C;&#x4F46;&#x662F;&#x4F60;&#x5F00;&#x5FC3;&#x5C31;&#x597D;&#x3002;</p>
<h3 id="css">CSS</h3>
<p><code>HTMLLayout</code> &#x521B;&#x5EFA;&#x7684; HTML &#x662F;&#x901A;&#x8FC7; CSS &#x6765;&#x63A7;&#x5236;&#x6837;&#x5F0F;&#x7684;&#x3002;&#x5728;&#x7F3A;&#x5C11;&#x6307;&#x5B9A;&#x547D;&#x4EE4;&#x7684;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;<code>HTMLLayout</code> &#x4F1A;&#x4F7F;&#x7528;&#x5185;&#x90E8;&#x9ED8;&#x8BA4;&#x7684;&#x6837;&#x5F0F;&#x3002;&#x4F46;&#x662F;&#xFF0C;&#x4F60;&#x53EF;&#x4EE5;&#x544A;&#x8BC9; <code>HTMLLayout</code> &#x53BB;&#x4F7F;&#x7528;&#x5916;&#x90E8;&#x7684; CSS &#x6587;&#x4EF6;&#x3002;&#x901A;&#x8FC7;&#x5728; <code>&lt;layout&gt;</code> &#x5143;&#x7D20;&#x5185;&#x7F6E; <code>&lt;cssBuilder&gt;</code> &#x5143;&#x7D20;&#x53EF;&#x4EE5;&#x505A;&#x5230;&#x3002;&#x5982;&#x4E0B;&#x6240;&#x793A;&#xFF1A;</p>
<pre><code class="lang-xml"><span class="hljs-tag">&lt;<span class="hljs-name">layout</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.classic.html.HTMLLayout&quot;</span>&gt;</span>
  <span class="hljs-tag">&lt;<span class="hljs-name">pattern</span>&gt;</span>%relative...%msg<span class="hljs-tag">&lt;/<span class="hljs-name">pattern</span>&gt;</span>
  <span class="hljs-tag">&lt;<span class="hljs-name">cssBuilder</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.classic.html.UrlCssBuilder&quot;</span>&gt;</span>
    <span class="hljs-comment">&lt;!-- css &#x6587;&#x4EF6;&#x7684;&#x8DEF;&#x5F84; --&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">url</span>&gt;</span>http://...<span class="hljs-tag">&lt;/<span class="hljs-name">url</span>&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">cssBuilder</span>&gt;</span> 
<span class="hljs-tag">&lt;/<span class="hljs-name">layout</span>&gt;</span>
</code></pre>
<p><code>HTMLLayout</code> &#x901A;&#x5E38;&#x4E0E; <code>SMTPAppender</code> &#x914D;&#x5408;&#x4F7F;&#x7528;&#xFF0C;&#x6240;&#x4EE5;&#x90AE;&#x4EF6;&#x53EF;&#x4EE5;&#x88AB;&#x683C;&#x5F0F;&#x5316;&#x6210; HTML&#x3002;</p>
<h2 id="log4j-xmllayout">Log4j XMLLayout</h2>
<p><a href="https://logback.qos.ch/xref/ch/qos/logback/classic/log4j/XMLLayout.html" target="_blank">XMLLayout</a> (logback-classic &#x7684;&#x4E00;&#x90E8;&#x5206;) &#x751F;&#x6210;&#x4E00;&#x4E2A; log4j.dtd &#x683C;&#x5F0F;&#x7684;&#x6587;&#x4EF6;&#xFF0C;&#x7528;&#x6765;&#x4E0E;&#x7C7B;&#x4F3C; <a href="http://logging.apache.org/chainsaw/index.html" target="_blank">Chainsaw</a> &#x4EE5;&#x53CA; <a href="http://vigilog.sourceforge.net/" target="_blank">Vigilog</a> &#x8FD9;&#x6837;&#x7684;&#x5DE5;&#x5177;&#x8FDB;&#x884C;&#x4EA4;&#x4E92;&#x64CD;&#x4F5C;&#xFF0C;&#x8FD9;&#x4E9B;&#x5DE5;&#x5177;&#x53EF;&#x4EE5;&#x5904;&#x7406;&#x7531; <a href="http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/xml/XMLLayout.html" target="_blank">log4j XMLLayout</a> &#x751F;&#x6210;&#x7684;&#x6587;&#x4EF6;&#x3002;</p>
<p>&#x8DDF; log4j 1.2.15 &#x7248;&#x672C;&#x7684; XMLLayout &#x4E00;&#x6837;&#xFF0C;logback-classic &#x4E2D;&#x7684; XMLLayout &#x63A5;&#x6536;&#x4E24;&#x4E2A; boolean &#x5C5E;&#x6027;&#xFF1A;<code>locationInfo</code> &#x4E0E; <code>properties</code>&#x3002;&#x8BBE;&#x7F6E; <code>locationInfo</code> &#x7684;&#x503C;&#x4E3A; true&#xFF0C;&#x53EF;&#x4EE5;&#x5728;&#x6BCF;&#x4E2A;&#x4E8B;&#x4EF6;&#x4E2D;&#x5F00;&#x542F;&#x5305;&#x542B;&#x4F4D;&#x7F6E;&#x4FE1;&#x606F; (&#x8C03;&#x7528;&#x8005;&#x7684;&#x6570;&#x636E;)&#x3002;&#x8BBE;&#x7F6E; <code>properties</code> &#x4E3A; true&#xFF0C;&#x53EF;&#x4EE5;&#x5F00;&#x542F;&#x5305;&#x542B; MDC &#x4FE1;&#x606F;&#x3002;&#x9ED8;&#x8BA4;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x4E24;&#x4E2A;&#x5C5E;&#x6027;&#x90FD;&#x8BBE;&#x7F6E;&#x4E3A; false&#x3002;</p>
<p>&#x4E0B;&#x9762;&#x662F;&#x4E00;&#x4E2A;&#x793A;&#x4F8B;&#xFF1A;</p>
<blockquote>
<p>  Example: <em>log4jXMLLayout.xml</em> </p>
</blockquote>
<pre><code class="lang-xml"><span class="hljs-tag">&lt;<span class="hljs-name">configuration</span>&gt;</span>
  <span class="hljs-tag">&lt;<span class="hljs-name">appender</span> <span class="hljs-attr">name</span>=<span class="hljs-string">&quot;FILE&quot;</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.core.FileAppender&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">file</span>&gt;</span>test.xml<span class="hljs-tag">&lt;/<span class="hljs-name">file</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">encoder</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.core.encoder.LayoutWrappingEncoder&quot;</span>&gt;</span>
      <span class="hljs-tag">&lt;<span class="hljs-name">layout</span> <span class="hljs-attr">class</span>=<span class="hljs-string">&quot;ch.qos.logback.classic.log4j.XMLLayout&quot;</span>&gt;</span>
        <span class="hljs-tag">&lt;<span class="hljs-name">locationInfo</span>&gt;</span>true<span class="hljs-tag">&lt;/<span class="hljs-name">locationInfo</span>&gt;</span>
      <span class="hljs-tag">&lt;/<span class="hljs-name">layout</span>&gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">encoder</span>&gt;</span> 
  <span class="hljs-tag">&lt;/<span class="hljs-name">appender</span>&gt;</span> 

  <span class="hljs-tag">&lt;<span class="hljs-name">root</span> <span class="hljs-attr">level</span>=<span class="hljs-string">&quot;DEBUG&quot;</span>&gt;</span>
    <span class="hljs-tag">&lt;<span class="hljs-name">appender-ref</span> <span class="hljs-attr">ref</span>=<span class="hljs-string">&quot;FILE&quot;</span> /&gt;</span>
  <span class="hljs-tag">&lt;/<span class="hljs-name">root</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">configuration</span>&gt;</span>
</code></pre>
<h1 id="logback-access">Logback access</h1>
<p>&#x5927;&#x591A;&#x6570; logback-access &#x7684; layout &#x4EC5;&#x4EC5;&#x53EA;&#x662F; logback-classic &#x7684; layout &#x7684;&#x6539;&#x7F16;&#x3002;logback-classic &#x4E0E; logback-access &#x6A21;&#x5757;&#x5B9A;&#x4F4D;&#x4E0D;&#x540C;&#x7684;&#x9700;&#x6C42;&#xFF0C;&#x4F46;&#x662F;&#x90FD;&#x63D0;&#x4F9B;&#x4E86;&#x7C7B;&#x4F3C;&#x7684;&#x529F;&#x80FD;&#x3002;</p>
<h2 id="&#x5199;&#x4F60;&#x81EA;&#x5DF1;&#x7684;-layout">&#x5199;&#x4F60;&#x81EA;&#x5DF1;&#x7684; layout</h2>
<p>&#x5728; logback-access &#x4E2D;&#x5199;&#x4E00;&#x4E2A;&#x5B9A;&#x5236;&#x7684; <code>Layout</code> &#x4E0E;&#x5728; logback-classic &#x7684; <code>Layout</code> &#x4E2D;&#x51E0;&#x4E4E;&#x4E00;&#x81F4;&#x3002;</p>
<h3 id="patternlayout">PatternLayout</h3>
<p>&#x914D;&#x7F6E; logback-access &#x4E2D;&#x7684; <a href="https://logback.qos.ch/xref/ch/qos/logback/access/PatternLayout.html" target="_blank"><code>PatternLayout</code></a>&#xFF0C;&#x4E0E;&#x5728; logback-classic &#x4E2D;&#x914D;&#x7F6E;&#x76F8;&#x540C;&#x3002;&#x4F46;&#x662F;&#x5B83;&#x6DFB;&#x52A0;&#x4E86;&#x4E00;&#x4E9B;&#x989D;&#x5916;&#x7684;&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;&#x6765;&#x9002;&#x5E94; HTTP &#x8BF7;&#x6C42;&#x4EE5;&#x53CA; HTTP &#x54CD;&#x5E94;&#x4E2D;&#x7279;&#x5B9A;&#x4FE1;&#x606F;&#x4F4D;&#x7684;&#x8BB0;&#x5F55;&#x3002;</p>
<p>&#x4E0B;&#x8868;&#x662F; logback-access &#x4E2D; <code>PatternLayout</code> &#x7684;&#x76F8;&#x5173;&#x8F6C;&#x6362;&#x8BF4;&#x660E;&#x7B26;&#x3002;</p>
<table>
<thead>
<tr>
<th style="text-align:left">&#x8F6C;&#x6362;&#x5B57;&#x7B26;</th>
<th>&#x6548;&#x679C;</th>
</tr>
</thead>
<tbody>
<tr>
<td style="text-align:left"><strong>a / remoteIP</strong></td>
<td>&#x8FDC;&#x7A0B; IP &#x5730;&#x5740;</td>
</tr>
<tr>
<td style="text-align:left"><strong>A / localIP</strong></td>
<td>&#x672C;&#x5730; IP &#x5730;&#x5740;</td>
</tr>
<tr>
<td style="text-align:left"><strong>b / B / bytesSent</strong></td>
<td>&#x54CD;&#x5E94;&#x5185;&#x5BB9;&#x7684;&#x957F;&#x5EA6;</td>
</tr>
<tr>
<td style="text-align:left"><strong>h / clientHost</strong></td>
<td>&#x8FDC;&#x7A0B; host</td>
</tr>
<tr>
<td style="text-align:left"><strong>H / protocol</strong></td>
<td>&#x8BF7;&#x6C42;&#x534F;&#x8BAE;</td>
</tr>
<tr>
<td style="text-align:left"><strong>l</strong></td>
<td>&#x8FDC;&#x7A0B;&#x65E5;&#x5FD7;&#x540D;&#xFF0C;&#x5728; logback-access &#x4E2D;&#xFF0C;&#x8F6C;&#x6362;&#x5668;&#x603B;&#x662F;&#x8FD4;&#x56DE; &quot;-&quot;</td>
</tr>
<tr>
<td style="text-align:left"><strong>reqParameter{paramName}</strong></td>
<td>&#x54CD;&#x5E94;&#x53C2;&#x6570;&#x3002;<br>&#x8FD9;&#x4E2A;&#x8F6C;&#x6362;&#x5B57;&#x7B26;&#x5728;&#x82B1;&#x62EC;&#x53F7;&#x4E2D;&#x63A5;&#x53D7;&#x4E00;&#x4E2A;&#x53C2;&#x6570;&#xFF0C;&#x5728;&#x8BF7;&#x6C42;&#x4E2D;&#x5BFB;&#x627E;&#x76F8;&#x5E94;&#x7684;&#x53C2;&#x6570;&#x3002;<br> <strong>%reqParameter{input_data}</strong> &#x5C55;&#x793A;&#x76F8;&#x5E94;&#x7684;&#x53C2;&#x6570;&#x3002;</td>
</tr>
<tr>
<td style="text-align:left"><strong>i{header} / header{header}</strong></td>
<td>&#x8BF7;&#x6C42;&#x5934;&#x3002;<br> <strong>%header{Referer}</strong> &#x663E;&#x793A;&#x8BF7;&#x6C42;&#x7684;&#x6765;&#x6E90;&#x3002;<br>&#x5982;&#x679C;&#x6CA1;&#x6709;&#x6307;&#x5B9A;&#x9009;&#x9879;&#xFF0C;&#x5C06;&#x4F1A;&#x5C55;&#x793A;&#x6240;&#x6709;&#x53EF;&#x7528;&#x7684;&#x8BF7;&#x6C42;&#x5934;</td>
</tr>
<tr>
<td style="text-align:left"><strong>m / requestMethod</strong></td>
<td>&#x8BF7;&#x6C42;&#x65B9;&#x6CD5;</td>
</tr>
<tr>
<td style="text-align:left"><strong>r / requestURL</strong></td>
<td>&#x8BF7;&#x6C42; URL</td>
</tr>
<tr>
<td style="text-align:left"><strong>s / statusCode</strong></td>
<td>&#x8BF7;&#x6C42;&#x72B6;&#x6001;&#x7801;</td>
</tr>
<tr>
<td style="text-align:left"><strong>D / elapsedTime</strong></td>
<td>&#x8BF7;&#x6C42;&#x6240;&#x8017;&#x8D39;&#x7684;&#x65F6;&#x95F4;&#xFF0C;&#x5355;&#x4F4D;&#x4E3A;&#x6BEB;&#x79D2;</td>
</tr>
<tr>
<td style="text-align:left"><strong>T / elapsedSeconds</strong></td>
<td>&#x8BF7;&#x6C42;&#x6240;&#x8017;&#x8D39;&#x7684;&#x65F6;&#x95F4;&#xFF0C;&#x5355;&#x4F4D;&#x4E3A;&#x79D2;</td>
</tr>
<tr>
<td style="text-align:left"><strong>t / date</strong></td>
<td>&#x8F93;&#x51FA;&#x65E5;&#x5FD7;&#x4E8B;&#x4EF6;&#x7684;&#x65E5;&#x671F;&#x3002;&#x65E5;&#x671F;&#x8BF4;&#x660E;&#x7B26;&#x9700;&#x8981;&#x7528;&#x82B1;&#x62EC;&#x53F7;&#x6307;&#x5B9A;&#x3002;&#x65E5;&#x671F;&#x683C;&#x5F0F;&#x6765;&#x6E90; <code>java.text.SimpleDateFormat</code>&#x3002;<em>ISO8601</em> &#x4E5F;&#x662F;&#x4E00;&#x4E2A;&#x6709;&#x6548;&#x7684;&#x503C;&#x3002;<br>&#x4F8B;&#x5982;&#xFF0C;<strong>%t{HH:mm:ss,SSS}</strong> &#x6216;&#x8005; <strong>%t{dd MMM yyyy ;HH:mm:ss,SSS}</strong>&#x3002;&#x5982;&#x679C;&#x6CA1;&#x6709;&#x6307;&#x5B9A;&#x65E5;&#x671F;&#x683C;&#x5F0F;&#x5B57;&#x7B26;&#xFF0C;&#x90A3;&#x4E48;&#x4F1A;&#x9ED8;&#x8BA4;&#x6307;&#x5B9A;&#x4E3A; <strong>%t{dd/MMM/yyyy:HH:mm:ss Z}</strong></td>
</tr>
<tr>
<td style="text-align:left"><strong>u / user</strong></td>
<td>&#x8FDC;&#x7A0B;&#x7528;&#x6237;</td>
</tr>
<tr>
<td style="text-align:left"><strong>q / queryString</strong></td>
<td>&#x8BF7;&#x6C42;&#x67E5;&#x8BE2;&#x5B57;&#x7B26;&#x4E32;&#xFF0C;&#x524D;&#x7F00;&#x4E3A; &apos;?&apos;</td>
</tr>
<tr>
<td style="text-align:left"><strong>U / requestURI</strong></td>
<td>&#x8BF7;&#x6C42; URI</td>
</tr>
<tr>
<td style="text-align:left"><strong>S / sessionID</strong></td>
<td>Session ID.</td>
</tr>
<tr>
<td style="text-align:left"><strong>v / server</strong></td>
<td>&#x670D;&#x52A1;&#x5668;&#x540D;</td>
</tr>
<tr>
<td style="text-align:left"><strong>I / threadName</strong></td>
<td>&#x5904;&#x7406;&#x8BE5;&#x6761;&#x8BF7;&#x6C42;&#x7684;&#x7EBF;&#x7A0B;</td>
</tr>
<tr>
<td style="text-align:left"><strong>localPort</strong></td>
<td>&#x672C;&#x5730;&#x7AEF;&#x53E3;</td>
</tr>
<tr>
<td style="text-align:left"><strong>reqAttribute{attributeName}</strong></td>
<td>&#x8BF7;&#x6C42;&#x7684;&#x5C5E;&#x6027;&#x3002;<br><strong>%reqAttribute{SOME_ATTRIBUTE}</strong> &#x5C55;&#x793A;&#x76F8;&#x5E94;&#x7684;&#x5C5E;&#x6027;&#x3002;</td>
</tr>
<tr>
<td style="text-align:left"><strong>reqCookie{cookie}</strong></td>
<td>&#x8BF7;&#x6C42; cookie&#x3002;<br><strong>%cookie{COOKIE_NAME}</strong> &#x5C55;&#x793A;&#x76F8;&#x5E94;&#x7684; cookie&#x3002;</td>
</tr>
<tr>
<td style="text-align:left"><strong>responseHeader{header}</strong></td>
<td>&#x54CD;&#x5E94;&#x5934;&#x3002;<br><strong>%header{Referer}</strong> &#x5C55;&#x793A;&#x54CD;&#x5E94;&#x7684;&#x6765;&#x6E90;&#x3002;</td>
</tr>
<tr>
<td style="text-align:left"><strong>requestContent</strong></td>
<td>&#x5C55;&#x793A;&#x8BF7;&#x6C42;&#x7684;&#x5185;&#x5BB9;&#xFF0C;&#x5373;&#x8BF7;&#x6C42;&#x7684; <code>InputStream</code>&#x3002;&#x5B83;&#x4E0E; <a href="https://logback.qos.ch/xref/ch/qos/logback/access/servlet/TeeFilter.html" target="_blank"><code>TeeFilter</code></a> &#x7ED3;&#x5408;&#x4F7F;&#x7528;&#x3002;&#x4E00;&#x4E2A;&#x4F7F;&#x7528;  <a href="https://logback.qos.ch/xref/ch/qos/logback/access/servlet/TeeHttpServletRequest.html" target="_blank"><code>TeeHttpServletRequest</code></a> &#x66FF;&#x4EE3;  <code>HttpServletRequest</code> &#x7684;  javax.servlet.Filter&#x3002;&#x524D;&#x8005;&#x53EF;&#x4EE5;&#x591A;&#x6B21;&#x8BBF;&#x95EE;&#x8BF7;&#x6C42;&#x7684; <code>InputStream</code> &#x800C;&#x4E0D;&#x4F1A;&#x4E22;&#x5931;&#x5185;&#x5BB9;&#x3002;</td>
</tr>
<tr>
<td style="text-align:left"><strong>fullRequest</strong></td>
<td>&#x8BF7;&#x6C42;&#x7684;&#x6570;&#x636E;&#x3002;&#x5305;&#x62EC;&#x6240;&#x6709;&#x7684;&#x8BF7;&#x6C42;&#x5934;&#x4EE5;&#x53CA;&#x8BF7;&#x6C42;&#x5185;&#x5BB9;&#x3002;</td>
</tr>
<tr>
<td style="text-align:left"><strong>responseContent</strong></td>
<td>&#x5C55;&#x793A;&#x54CD;&#x5E94;&#x7684;&#x5185;&#x5BB9;&#xFF0C;&#x4E5F;&#x5C31;&#x662F;&#x54CD;&#x5E94;&#x7684; <code>InputStream</code>&#x3002; &#x5B83;&#x4E0E; <a href="https://logback.qos.ch/xref/ch/qos/logback/access/servlet/TeeFilter.html" target="_blank"><code>TeeFilter</code></a> &#x7ED3;&#x5408;&#x4F7F;&#x7528;&#x3002;&#x4E00;&#x4E2A;&#x4F7F;&#x7528;  <a href="https://logback.qos.ch/xref/ch/qos/logback/access/servlet/TeeHttpServletResponse.html" target="_blank"><code>TeeHttpServletResponse</code></a> &#x66FF;&#x4EE3; <code>HttpServletResponse</code> &#x7684;  <code>javax.servlet.Filter</code>&#x3002;&#x524D;&#x8005;&#x53EF;&#x4EE5;&#x591A;&#x6B21;&#x8BBF;&#x95EE;&#x54CD;&#x5E94; (&#x539F;&#x6587;&#x4E3A;&#x8BF7;&#x6C42;) &#x7684; <code>InputStream</code> &#x800C;&#x4E0D;&#x4F1A;&#x4E22;&#x5931;&#x5185;&#x5BB9;&#x3002;</td>
</tr>
<tr>
<td style="text-align:left"><strong>fullResponse</strong></td>
<td>&#x83B7;&#x53D6;&#x54CD;&#x5E94;&#x6240;&#x6709;&#x53EF;&#x7528;&#x7684;&#x6570;&#x636E;&#xFF0C;&#x5305;&#x62EC;&#x6240;&#x6709;&#x7684;&#x54CD;&#x5E94;&#x5934;&#x4EE5;&#x53CA;&#x54CD;&#x5E94;&#x5185;&#x5BB9;&#x3002;</td>
</tr>
</tbody>
</table>
<p>logback-access &#x7684; <code>PatternLayout</code> &#x80FD;&#x591F;&#x8BC6;&#x522B;&#x4E09;&#x4E2A;&#x5173;&#x952E;&#x5B57;&#xFF0C;&#x6709;&#x70B9;&#x7C7B;&#x4F3C;&#x5FEB;&#x6377;&#x952E;&#x3002;</p>
<table>
<thead>
<tr>
<th>&#x5173;&#x952E;&#x5B57;</th>
<th>&#x76F8;&#x7B49;&#x7684;&#x8F6C;&#x6362;&#x6A21;&#x5F0F;</th>
</tr>
</thead>
<tbody>
<tr>
<td><em>common</em> or <em>CLF</em></td>
<td><em>%h %l %u [%t] &quot;%r&quot; %s %b</em></td>
</tr>
<tr>
<td><em>combined</em></td>
<td><em>%h %l %u [%t] &quot;%r&quot; %s %b &quot;%i{Referer}&quot; &quot;%i{User-Agent}&quot;</em></td>
</tr>
</tbody>
</table>
<p>&#x5173;&#x952E;&#x5B57; <em>common</em> &#x5BF9;&#x5E94; <em>&apos;%h %l %u [%t] &quot;%r&quot; %s %b&apos;</em>&#xFF0C;&#x5206;&#x522B;&#x5C55;&#x793A;&#x5BA2;&#x6237;&#x7AEF;&#x4E3B;&#x673A;&#xFF0C;&#x8FDC;&#x7A0B;&#x65E5;&#x5FD7;&#x540D;&#xFF0C;&#x7528;&#x6237;&#xFF0C;&#x65E5;&#x671F;&#xFF0C;&#x8BF7;&#x6C42; URL&#xFF0C;&#x72B6;&#x6001;&#x7801;&#xFF0C;&#x4EE5;&#x53CA;&#x54CD;&#x5E94;&#x5185;&#x5BB9;&#x7684;&#x957F;&#x5EA6;&#x3002;</p>
<p>&#x5173;&#x952E;&#x5B57; <em>combined</em> &#x5BF9;&#x5E94; <em>&apos;%h %l %u [%t] &quot;%r&quot; %s %b &quot;%i{Referer}&quot; &quot;%i{User-Agent}&quot;&apos;</em>&#x3002;&#x8DDF; <em>common</em> &#x6709;&#x70B9;&#x7C7B;&#x4F3C;&#xFF0C;&#x4F46;&#x662F;&#x5B83;&#x8FD8;&#x4F1A;&#x518D;&#x663E;&#x793A;&#x4E24;&#x4E2A;&#x8BF7;&#x6C42;&#x5934;&#xFF0C;referer &#x4EE5;&#x53CA; user-agent&#x3002;</p>
<h3 id="htmllayout">HTMLLayout</h3>
<p>logback-access &#x4E2D;&#x7684; <a href="https://logback.qos.ch/xref/ch/qos/logback/access/html/HTMLLayout.html" target="_blank"><code>HTMLLayout</code></a> &#x4E0E; logback-classic &#x4E2D;&#x7684; <a href="https://logback.qos.ch/manual/layouts.html#ClassicHTMLLayout" target="_blank"><code>HTMLLayout</code></a> &#x6709;&#x70B9;&#x7C7B;&#x4F3C;&#x3002;</p>
<p>&#x9ED8;&#x8BA4;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x5B83;&#x4F1A;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x5305;&#x542B;&#x5982;&#x4E0B;&#x6570;&#x636E;&#x7684;&#x8868;&#x683C;&#xFF1A;</p>
<ul>
<li>&#x8BF7;&#x6C42; IP (Remote IP)</li>
<li>&#x65E5;&#x671F; (Date)</li>
<li>&#x8BF7;&#x6C42; URL (Request URL)</li>
<li>&#x72B6;&#x6001;&#x7801; (Status code)</li>
<li>&#x5185;&#x5BB9;&#x957F;&#x5EA6; (Content Length)</li>
</ul>
<p>&#x4E0B;&#x9762;&#x662F; logback-access &#x4E2D;&#x7684; <code>HTMLLayout</code> &#x8F93;&#x51FA;&#x7684;&#x4E00;&#x4E2A;&#x4F8B;&#x5B50;&#xFF1A;</p>
<p><img src="images/htmlLayoutAccess.gif" alt=""></p>
<p>&#x8FD8;&#x6709;&#x6BD4;&#x771F;&#x5B9E;&#x7684;&#x4F8B;&#x5B50;&#x66F4;&#x597D;&#x7684;&#x4F8B;&#x5B50;&#x5417;&#xFF1F;&#x6211;&#x4EEC;&#x81EA;&#x5DF1;&#x7684; log4j.properties &#x7528;&#x4E8E; logback <a href="http://logback.qos.ch/translator/" target="_blank">&#x7FFB;&#x8BD1;&#x5668;</a>&#xFF0C;&#x5145;&#x5206;&#x7684;&#x5229;&#x7528;&#x4E86; logback-access &#x5728;&#x7EBF;&#x6F14;&#x793A; <code>RollingFileAppender</code> &#x4E0E; <code>HTMLLayout</code> &#x7684;&#x8F93;&#x51FA;&#x3002;</p>
<p>&#x6BCF;&#x4E00;&#x4E2A;&#x65B0;&#x7684;&#x7528;&#x6237;&#x8BF7;&#x6C42; <a href="http://logback.qos.ch/translator/" target="_blank">&#x7FFB;&#x8BD1;&#x5668;</a> &#x8FD9;&#x4E2A;&#x7F51;&#x7AD9;&#xFF0C;&#x4E00;&#x4E2A;&#x65B0;&#x7684;&#x6761;&#x76EE;&#x5C31;&#x4F1A;&#x6DFB;&#x52A0;&#x5230;&#x8BBF;&#x95EE;&#x65E5;&#x5FD7;&#xFF0C;&#x4F60;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;<a href="https://logback.qos.ch/translator/logs/access.html" target="_blank">&#x8FD9;&#x4E2A;&#x94FE;&#x63A5;</a> &#x67E5;&#x770B;&#x3002;</p>



                                
                                </section>
                            
    </div>
    <div class="search-results">
        <div class="has-results">
            
            <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
            <ul class="search-results-list"></ul>
            
        </div>
        <div class="no-results">
            
            <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
            
        </div>
    </div>
</div>

                        </div>
                    </div>
                
            </div>

            
                
                <a href="05第五章Encoder.html" class="navigation navigation-prev " aria-label="Previous page: 第五章：Encoder">
                    <i class="fa fa-angle-left"></i>
                </a>
                
                
                <a href="07第七章Filters.html" class="navigation navigation-next " aria-label="Next page: 第七章：Filters">
                    <i class="fa fa-angle-right"></i>
                </a>
                
            
        
    </div>

    <script>
        var gitbook = gitbook || [];
        gitbook.push(function() {
            gitbook.page.hasChanged({"page":{"title":"第六章：Layouts","level":"1.7","depth":1,"next":{"title":"第七章：Filters","level":"1.8","depth":1,"path":"07第七章Filters.md","ref":"07第七章Filters.md","articles":[]},"previous":{"title":"第五章：Encoder","level":"1.6","depth":1,"path":"05第五章Encoder.md","ref":"05第五章Encoder.md","articles":[]},"dir":"ltr"},"config":{"plugins":["add-js-css","myseo"],"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"pluginsConfig":{"add-js-css":{"js":["./lib/site.js"]},"myseo":{"description":"logback中文网包含了logback中文文档，最新资讯，应用案例等。logback 继承自 log4j，它建立在有十年工业经验的日志系统之上。它比其它所有的日志系统更快并且更小，包含了许多独特并且有用的特性。","keywords":"logback中文文档, logback api文档, logback log4j,springboot logback,logback日志类型","titlePrefix":"logback中文网|"},"highlight":{},"search":{},"lunr":{"maxIndexSize":1000000,"ignoreSpecialCharacters":false},"sharing":{"facebook":true,"twitter":true,"google":false,"weibo":false,"instapaper":false,"vk":false,"all":["facebook","google","twitter","weibo","instapaper"]},"fontsettings":{"theme":"white","family":"sans","size":2},"theme-default":{"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false}},"theme":"default","keywords":"","pdf":{"pageNumbers":true,"fontSize":12,"fontFamily":"Arial","paperSize":"a4","chapterMark":"pagebreak","pageBreaksBefore":"/","margin":{"right":62,"left":62,"top":56,"bottom":56}},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"variables":{},"title":"logback中文手册","gitbook":"*","description":""},"file":{"path":"06第六章Layouts.md","mtime":"2019-02-12T05:09:29.000Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2019-02-24T03:19:05.191Z"},"basePath":".","book":{"language":""}});
        });
    </script>
</div>

        
    <script src="gitbook/gitbook.js"></script>
    <script src="gitbook/theme.js"></script>
    
        
        <script src="gitbook/gitbook-plugin-add-js-css/fda70cfc36440304bb976a11f47eb151-site.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-search/search-engine.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-search/search.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-lunr/lunr.min.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-lunr/search-lunr.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-sharing/buttons.js"></script>
        
    
        
        <script src="gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
        
    

    </body>
</html>

